Пользовательские блоки
Вы можете определять пользовательские блоки внутри файлов *.vue
. Загрузчики, применяемые к такому блоку, будут определяться сопоставлением по атрибуту lang
блока, имени тега блока, и правил в вашей конфигурации webpack.
Если указан атрибут lang
, пользовательский блок будет обработан как файл с расширением, указанном в lang
.
Вы также можете использовать resourceQuery
для определения правила для блока без атрибута lang
. Например, для сопоставления пользовательского блока <foo>
:
{
module: {
rules: [
{
resourceQuery: /blockType=foo/,
loader: "loader-to-use"
}
];
}
}
Если для пользовательского блока будет найдено правило — он будет им обработан; в противном случае пользовательский блок будет тихо проигнорирован.
Кроме того, если пользовательский блок экспортирует функцию в качестве конечного результата после обработки всеми соответствующими загрузчиками, то эта функция будет вызываться с компонентом файла *.vue
в качестве параметра.
Пример
Небольшой пример внедрения пользовательского блока <docs>
в компонент таким образом, что он будет доступен во время выполнения.
Для внедрения содержимого пользовательского блока мы напишем собственный загрузчик:
module.exports = function(source, map) {
this.callback(
null,
`export default function (Component) {
Component.options.__docs = ${JSON.stringify(source)}
}`,
map
);
};
Настроим webpack использовать наш загрузчик для пользовательских блоков <docs>
.
// wepback.config.js
module.exports = {
module: {
rules: [
{
resourceQuery: /blockType=docs/,
loader: require.resolve("./docs-loader.js")
}
]
}
};
Теперь мы можем получить доступ к содержимому блока <docs>
импортированного компонента на этапе выполнения.
<!-- ComponentB.vue -->
<template>
<div>Hello</div>
</template>
<docs>
This is the documentation for component B.
</docs>
<!-- ComponentA.vue -->
<template>
<div>
<ComponentB/>
<p>{{ docs }}</p>
</div>
</template>
<script>
import ComponentB from "./ComponentB.vue";
export default {
components: { ComponentB },
data() {
return {
docs: ComponentB.__docs
};
}
};
</script>