组件

源码
Nuxt Kit 提供了一组实用工具来帮助您处理组件。您可以全局或局部注册组件,也可以添加要扫描组件的目录。

组件是 Nuxt 应用的构建块。它们是可重用的 Vue 实例,可用于创建用户界面。在 Nuxt 中,components 目录下的组件默认会被自动导入。但如果您需要从替代目录导入组件,或希望按需选择性地导入组件,@nuxt/kit 提供了 addComponentsDiraddComponent 方法。这些工具允许您自定义组件配置,以更好地满足您的需求。

观看关于注入组件的 Vue School 视频。

addComponentsDir

注册一个目录以扫描组件,并在仅使用时导入。请注意,除非您指定 global: true 选项,否则这不会将组件注册为全局组件。

用法

export default defineNuxtModule({
  meta: {
    name: '@nuxt/ui',
    configKey: 'ui',
  },
  setup () {
    addComponentsDir({
      path: resolve('./runtime/components'),
      prefix: 'U',
      pathPrefix: false,
    })
  },
})

类型

function addComponentsDir (dir: ComponentsDir, opts: { prepend?: boolean } = {}): void

参数

dir 一个包含以下属性的对象:

属性类型必填描述
pathstringtrue包含组件的目录路径(绝对或相对)。您可以使用 Nuxt 别名(~ 或 @)来引用项目内的目录,或直接使用类似于 require 的 npm 包路径。
patternstring | string[]false要针对指定路径运行的匹配模式。
ignorestring[]false要针对指定路径运行的忽略模式。
prefixstringfalse用此字符串为所有匹配的组件添加前缀。
pathPrefixbooleanfalse通过其路径为组件名称添加前缀。
prefetchbooleanfalse这些属性(prefetch/preload)在生产环境中用于配置带有 Lazy 前缀的组件如何通过 webpack 的魔法注释进行处理。更多信息见 webpack 文档
preloadbooleanfalse这些属性(prefetch/preload)在生产环境中用于配置带有 Lazy 前缀的组件如何通过 webpack 的魔法注释进行处理。更多信息见 webpack 文档
isAsyncbooleanfalse此标志表示组件应异步加载(使用单独的 chunk),无论是否使用 Lazy 前缀。
extendComponent(component: Component) => Promise<Component | void> | (Component | void)false每个在目录中发现的组件都会调用此函数。它接受一个组件对象并应返回一个组件对象或解析为组件对象的 Promise。
globalbooleanfalse启用后,将组件注册为全局可用。
islandbooleanfalse启用后,将组件注册为 island。您可以在 <NuxtIsland/> 组件说明中阅读有关 islands 的更多信息。
watchbooleanfalse监听指定路径的更改,包括文件添加和删除。
extensionsstring[]falseNuxt 构建器支持的扩展名。
transpile'auto' | booleanfalse使用 build.transpile 转译指定路径。如果设置为 'auto',则当路径中包含 node_modules/ 时会将 transpile: true 设置为 true。

opts

属性类型必填描述
prependbooleanfalse如果设置为 true,则该目录将使用 unshift() 添加到数组前端,而不是使用 push() 添加到数组末尾。

addComponent

注册一个组件以实现自动导入。

用法

import { addComponent, createResolver, defineNuxtModule } from '@nuxt/kit'

export default defineNuxtModule({
  meta: {
    name: '@nuxt/image',
    configKey: 'image',
  },
  setup () {
    const resolver = createResolver(import.meta.url)

    addComponent({
      name: 'NuxtImg',
      filePath: resolver.resolve('./runtime/components/NuxtImg.vue'),
    })

    addComponent({
      name: 'NuxtPicture',
      filePath: resolver.resolve('./runtime/components/NuxtPicture.vue'),
    })
  },
})

类型

function addComponent (options: AddComponentOptions): void

参数

options:一个包含以下属性的对象:

属性类型必填描述
namestringtrue组件名称。
filePathstringtrue组件路径。
pascalNamestringfalsePascalCase 的组件名称。如果未提供,将从组件名称生成。
kebabNamestringfalsekebab-case 的组件名称。如果未提供,将从组件名称生成。
exportstringfalse指定命名导出或默认导出。如果未提供,将设置为 'default'
shortPathstringfalse组件的短路径。如果未提供,将从组件路径生成。
chunkNamestringfalse组件的 chunk 名称。如果未提供,将从组件名称生成。
prefetchbooleanfalse这些属性(prefetch/preload)在生产环境中用于配置带有 Lazy 前缀的组件如何通过 webpack 的魔法注释进行处理。更多信息见 webpack 文档
preloadbooleanfalse这些属性(prefetch/preload)在生产环境中用于配置带有 Lazy 前缀的组件如何通过 webpack 的魔法注释进行处理。更多信息见 webpack 文档
globalbooleanfalse启用后,将该组件注册为全局可用。
islandbooleanfalse启用后,将该组件注册为 island。您可以在 <NuxtIsland/> 组件说明中阅读有关 islands 的更多信息。
mode'client' | 'server' | 'all'false此选项指示组件应在客户端、服务器还是两者都渲染。默认情况下,组件将在客户端和服务器上都渲染。
prioritynumberfalse组件的优先级:如果多个组件具有相同的名称,将使用优先级最高的组件。

示例

如果您希望从 npm 包自动导入一个组件,并且该组件是命名导出(而不是默认导出),您可以使用 export 选项来指定它。

import { addComponent, defineNuxtModule } from '@nuxt/kit'

export default defineNuxtModule({
  setup () {
    // import { MyComponent as MyAutoImportedComponent } from 'my-npm-package'
    addComponent({
      name: 'MyAutoImportedComponent',
      export: 'MyComponent',
      filePath: 'my-npm-package',
    })
  },
})