在 Nuxt 中安装 PrimeVue

在 Nuxt 项目中设置 PrimeVue。

PrimeVue 可在 npm 注册表上下载,同时提供官方 @primevue/nuxt-module


# Using npm
npm install primevue @primevue/themes
npm install --save-dev @primevue/nuxt-module

# Using yarn
yarn add primevue @primevue/themes
yarn add --dev @primevue/nuxt-module

# Using pnpm
pnpm add primevue @primevue/themes
pnpm add -D @primevue/nuxt-module

nuxt.config 文件中,将 @primevue/nuxt-module 添加到模块部分,并为模块的配置定义 primevue 对象。


export default defineNuxtConfig({
    modules: [
        '@primevue/nuxt-module'
    ],
    primevue: {
        /* Configuration */
    }
})

配置模块以使用像 Aura 这样的主题。


import Aura from '@primevue/themes/aura';

export default defineNuxtConfig({
    modules: [
        '@primevue/nuxt-module'
    ],
    primevue: {
        options: {
            theme: {
                preset: Aura
            }
        }
    }
})

nuxt-primevue 模块会自动注册组件并支持摇树优化,因此您可以立即开始使用它们。


<Button label="Verify" />

该模块默认安装 PrimeVue 插件。如果您希望手动配置 PrimeVue(例如使用 Nuxt 插件),请禁用此选项。


primevue: {
    usePrimeVue: true | false
}

PrimeVue 的主要配置设置,详情请参阅配置文档。


import Aura from '@primevue/themes/aura';

export default defineNuxtConfig({
    modules: [
        '@primevue/nuxt-module'
    ],
    primevue: {
        options: {
            ripple: true,
            inputVariant: 'filled',
            theme: {
                preset: Aura,
                options: {
                    prefix: 'p',
                    darkModeSelector: 'system',
                    cssLayer: false
                }
            }
        }
    }
})

自动导入功能会自动注册组件并支持摇树优化。默认为 true,禁用时使用 componentsdirectives 的 include/exclude 选项进行手动注册。


primevue: {
    autoImport: true|false
}

componentsdirectives 中使用 prefix 为注册添加前缀。


primevue: {
    autoImport: true|false,
    components: {
        prefix: 'org'
    },
    directives: {
        prefix: 'org'
    }
}

配置全局传递导入路径。


primevue: {
    importPT: { from: '@/passthrough/mycustompt.js' }
}

mycustompt.js 文件定义配置并导出它。


const MyCustomPT = {
    ...
    button: {
        root: 'my-button',
       ...
    },
    ...
}

export default MyCustomPT;

配置样式模式下主题自定义的主题配置路径。


primevue: {
    importTheme: { from: '@/themes/mytheme.js' },
}

mytheme.js 文件包含主题配置。


import { definePreset } from '@primevue/themes';
import Aura from '@primevue/themes/aura';

const MyPreset = definePreset(Aura, {
    semantic: {
        primary: {
            50: '{indigo.50}',
            100: '{indigo.100}',
            200: '{indigo.200}',
            300: '{indigo.300}',
            400: '{indigo.400}',
            500: '{indigo.500}',
            600: '{indigo.600}',
            700: '{indigo.700}',
            800: '{indigo.800}',
            900: '{indigo.900}',
            950: '{indigo.950}'
        }
    }
});

export default {
    preset: MyPreset,
    options: {
        darkModeSelector: '.p-dark'
    }
};


autoImport 禁用时,使用 includeexclude 进行手动注册。

要导入和注册的组件使用字符串数组的 include 选项定义。当值被忽略或使用 * 别名设置时,将注册所有组件。


primevue: {
    components: {
        include: ['Button', 'DataTable']
    }
}

如果导入所有组件,仍然可以使用 exclude 选项排除特定的组件。


primevue: {
    components: {
        include: '*',
        exclude: ['Galleria', 'Carousel']
    }
}

默认情况下,出于兼容性原因,Chart 和 Editor 组件被排除。要包含它们,只需将 exclude 选项设置为空列表即可。


primevue: {
    components: {
        exclude: []
    }
}

使用 prefix 选项为注册的组件名称添加前缀。


primevue: {
    components: {
        prefix: 'Prime'
        include: ['Button', 'DataTable']    /* Used as <PrimeButton /> and <PrimeDataTable /> */
    }
}

可以通过实现 name 函数进一步自定义组件注册,该函数获取一个表示导入元数据的对象。name 是组件的标签,as 是默认导出名称,from 是导入路径。


primevue: {
    components: {
        name: ({ name, as, from }) => {
            return name === 'Button' ? `My${name}` : name;
        },
        include: ['Button', 'DataTable']    /* Used as <MyButton /> and <DataTable /> */
    }
}

autoImport 禁用时,使用 includeexclude 进行手动注册。

要导入和注册的指令的名称使用 include 属性提供。当值被忽略或使用 * 别名设置时,将注册所有指令。


primevue: {
    directives: {
        include: ['Ripple', 'Tooltip']
    }
}

与组件类似,可以排除某些指令,并且可以自定义名称注册。


primevue: {
    directives: {
        include: '*',
        exclude: ['Ripple']
    }
}


primevue: {
    directives: {
        prefix: 'p'
        include: ['Ripple', 'Tooltip']    /* Used as v-pripple and v-ptooltip */
    }
}

确定要使用的可组合项,当默认值被忽略或设置为 * 时,将导入所有可组合项。


primevue: {
    composables: {
        include: ['useStyle']
    }
}

基于 Nuxt 的示例,具有不同的选项,可在 PrimeVue 示例存储库中找到。

欢迎来到 Prime UI 生态系统!一旦您启动并运行了 PrimeVue,我们建议您探索以下资源,以更深入地了解该库。