自定义块

优质
小牛编辑
137浏览
2023-12-01

在大于 10.2.0 中支持

.vue 文件中,你可以自定义语言块。自定义块的内容将由 vue-loader 的 options 中的 loader 对象中指定的 loader 处理,然后被组件模块依赖。类似 Loader 进阶配置中的配置,但使用的是标签名匹配,而不是 lang 属性。

如果找到一个与自定义块匹配的 loader,该自定义块将被处理;否则自定义块将被忽略。 另外,如果找到的 loader 返回一个函数,该函数将以 * .vue 文件的组件作为参数来调用。

单个文档文件的例子

这是提取自定义块 <docs> 的内容到单个 docs 文件中的例子:

component.vue

<docs>
## This is an Example component.
</docs>

<template>
  <h2 class="red">{{msg}}</h2>
</template>

<script>
export default {
  data () {
    return {
      msg: 'Hello from Component A!'
    }
  }
}
</script>

<style>
comp-a h2 {
  color: #f00;
}
</style>

webpack.config.js

var ExtractTextPlugin = require("extract-text-webpack-plugin")

module.exports = {
  module: {
    rules: [
      {
        test: /\.vue$/,
        loader: 'vue-loader',
        options: {
          loaders: {
            // 提取 <docs> 中的内容为原始文本
            'docs': ExtractTextPlugin.extract('raw-loader'),
          }
        }
      }
    ]
  },
  plugins: [
    // 输出 docs 到单个文件中
    new ExtractTextPlugin('docs.md')
  ]
}

运行时可用的文档

在 11.3.0+ 中支持

这里有一个向组件注入 <docs> 自定义块使其在运行时可用的例子。

docs-loader.js

为了使得自定义块内容被注入,我们需要一个自定义的 loader:

module.exports = function (source, map) {
  this.callback(null, 'module.exports = function(Component) {Component.options.__docs = ' +
    JSON.stringify(source) +
    '}', map)
}

webpack.config.js

现在我们将为 <docs> 自定义块配置我们的 webpack 自定义 loader。

const docsLoader = require.resolve('./custom-loaders/docs-loader.js')

module.exports = {
  module: {
    rules: [
      {
        test: /\.vue$/,
        loader: 'vue-loader',
        options: {
          loaders: {
            'docs': docsLoader
          }
        }
      }
    ]
  }
}

component.vue

现在我们可以在运行时访问已导入组件的 <docs> 块内容了。

<template>
  <div>
    <component-b />
    <p>{{ docs }}</p>
  </div>
</template>

<script>
import componentB from 'componentB';

export default = {
  data () {
    return {
      docs: componentB.__docs
    }
  },
  components: {componentB}
}
</script>