插件是自包含的代码,通常为 Vue 添加应用级别的功能。在 Nuxt 中,插件会自动从 app/plugins/ 目录导入。然而,如果你需要将插件与你的模块一起发布,Nuxt Kit 提供了 addPlugin 和 addPluginTemplate 方法。这些实用工具允许你自定义插件配置,以更好地满足你的需求。
addPlugin注册 Nuxt 插件并将其添加到插件数组中。
import { addPlugin, createResolver, defineNuxtModule } from '@nuxt/kit'
export default defineNuxtModule({
setup () {
const { resolve } = createResolver(import.meta.url)
addPlugin({
src: resolve('runtime/plugin.js'),
mode: 'client',
})
},
})
function addPlugin (plugin: NuxtPlugin | string, options?: AddPluginOptions): NuxtPlugin
plugin: 插件对象或插件路径字符串。如果提供了字符串,它将被转换为一个插件对象,其中 src 设置为该字符串值。
如果提供了插件对象,它必须具有以下属性
| 属性 | 类型 | 必需 | 描述 |
|---|---|---|---|
src | string | true | 插件文件的路径。 |
模式 | 'all' | 'server' | 'client' | false | 如果设置为 'all',插件将包含在客户端和服务器打包中。如果设置为 'server',插件将只包含在服务器打包中。如果设置为 'client',插件将只包含在客户端打包中。你还可以使用 .client 和 .server 修饰符来指定 src 选项,以便仅在客户端或服务器端使用插件。 |
order | number | false | 插件的顺序。这允许更精细地控制插件顺序,仅供高级用户使用。数字越小越先运行,用户插件默认为 0。建议将 order 设置为 -20(用于 pre-plugins,即在 Nuxt 插件之前运行的插件)和 20(用于 post-plugins,即在 Nuxt 插件之后运行的插件)之间的数字。 |
order。如果你只是需要在 Nuxt 默认插件之后注册插件,请使用 append。options: 可选对象,具有以下属性
| 属性 | 类型 | 必需 | 描述 |
|---|---|---|---|
append | boolean | false | 如果为 true,插件将追加到插件数组中。如果为 false,则将前置。默认为 false。 |
import { addPlugin, createResolver, defineNuxtModule } from '@nuxt/kit'
export default defineNuxtModule({
setup () {
const { resolve } = createResolver(import.meta.url)
addPlugin({
src: resolve('runtime/plugin.js'),
mode: 'client',
})
},
})
export default defineNuxtPlugin((nuxtApp) => {
const colorMode = useColorMode()
nuxtApp.hook('app:mounted', () => {
if (colorMode.preference !== 'dark') {
colorMode.preference = 'dark'
}
})
})
addPluginTemplate添加模板并注册为 Nuxt 插件。这对于需要在构建时生成代码的插件很有用。
import { addPluginTemplate, defineNuxtModule } from '@nuxt/kit'
export default defineNuxtModule({
setup (options) {
addPluginTemplate({
filename: 'module-plugin.mjs',
getContents: () => `import { defineNuxtPlugin } from '#app/nuxt'
export default defineNuxtPlugin({
name: 'module-plugin',
setup (nuxtApp) {
${options.log ? 'console.log("Plugin install")' : ''}
}
})`,
})
},
})
function addPluginTemplate (pluginOptions: NuxtPluginTemplate, options?: AddPluginOptions): NuxtPlugin
pluginOptions: 具有以下属性的插件模板对象
| 属性 | 类型 | 必需 | 描述 |
|---|---|---|---|
src | string | false | 模板路径。如果未提供 src,则必须提供 getContents。 |
filename | string | false | 模板文件名。如果未提供 filename,它将从 src 路径生成。在这种情况下,src 选项是必需的。 |
dst | string | false | 目标文件路径。如果未提供 dst,它将从 filename 路径和 nuxt buildDir 选项生成。 |
模式 | 'all' | 'server' | 'client' | false | 如果设置为 'all',插件将包含在客户端和服务器打包中。如果设置为 'server',插件将只包含在服务器打包中。如果设置为 'client',插件将只包含在客户端打包中。你还可以使用 .client 和 .server 修饰符来指定 src 选项,以便仅在客户端或服务器端使用插件。 |
options | Record<string, any> | false | 要传递给模板的选项。 |
getContents | (data: Record<string, any>) => string | Promise<string> | false | 一个将使用 options 对象调用的函数。它应该返回一个字符串或解析为字符串的 Promise。如果提供了 src,此函数将被忽略。 |
write | boolean | false | 如果设置为 true,模板将写入目标文件。否则,模板将仅在虚拟文件系统中使用。 |
order | number | false | 插件的顺序。这允许更精细地控制插件顺序,仅供高级用户使用。数字越小越先运行,用户插件默认为 0。建议将 order 设置为 -20(用于 pre-plugins,即在 Nuxt 插件之前运行的插件)和 20(用于 post-plugins,即在 Nuxt 插件之后运行的插件)之间的数字。 |
getContents 进行动态插件生成。除非必要,否则避免设置 order。options: 可选对象,具有以下属性
| 属性 | 类型 | 必需 | 描述 |
|---|---|---|---|
append | boolean | false | 如果为 true,插件将追加到插件数组中。如果为 false,则将前置。默认为 false。 |
当你需要在构建时动态生成插件代码时,请使用 addPluginTemplate。这允许你根据传递给它的选项生成不同的插件内容。例如,Nuxt 内部使用此函数生成 Vue 应用配置。
import { addPluginTemplate, defineNuxtModule } from '@nuxt/kit'
export default defineNuxtModule({
setup (_, nuxt) {
if (nuxt.options.vue.config && Object.values(nuxt.options.vue.config).some(v => v !== null && v !== undefined)) {
addPluginTemplate({
filename: 'vue-app-config.mjs',
write: true,
getContents: () => `import { defineNuxtPlugin } from '#app/nuxt'
export default defineNuxtPlugin({
name: 'nuxt:vue-app-config',
enforce: 'pre',
setup (nuxtApp) {
${Object.keys(nuxt.options.vue.config!)
.map(k => `nuxtApp.vueApp.config[${JSON.stringify(k)}] = ${JSON.stringify(nuxt.options.vue.config![k as 'idPrefix'])}`)
.join('\n')
}
}
})`,
})
}
},
})
这将根据提供的配置生成不同的插件代码。
export default defineNuxtConfig({
vue: {
config: {
idPrefix: 'nuxt',
},
},
})
import { defineNuxtPlugin } from '#app/nuxt'
export default defineNuxtPlugin({
name: 'nuxt:vue-app-config',
enforce: 'pre',
setup (nuxtApp) {
nuxtApp.vueApp.config.idPrefix = 'nuxt'
},
})