On-demand PrimeVue components with auto imports and tree-shaking.
PrimeVue components need to be imported and configured individually. In the next section, we'll cleanup the code using auto imports.
import { createApp } from "vue";
import PrimeVue from "primevue/config";
import InputText from 'primevue/inputtext';
import Button from 'primevue/button';
import App from './App.vue'
const app = createApp(App);
app.use(PrimeVue);
app.component('InputText', InputText);
app.component('Button', Button);
The unplugin-vue-components library can automatically import and register PrimeVue components with the help of @primevue/auto-import-resolver. Begin with installing the packages as dev dependencies.
npm i unplugin-vue-components -D
npm i @primevue/auto-import-resolver -D
Next step would be adding the PrimeVueResolver at vite.config using the Components plugin.
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import Components from 'unplugin-vue-components/vite';
import {PrimeVueResolver} from '@primevue/auto-import-resolver';
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
vue(),
Components({
resolvers: [
PrimeVueResolver()
]
})]
})
That's it, now the initialization code can be refactored as the following. For configuration like namespacing, visit the official documentation.
import { createApp } from "vue";
import PrimeVue from "primevue/config";
import App from './App.vue'
const app = createApp(App);
app.use(PrimeVue);
A complete example using PrimeVue with auto imports is available at the playground.