With the release of Vue 3.5, Vue has more support for custom elements. This repository should have completed its mission (a transitional solution before Vue supports more features for custom elements), so this repository should not support 3.5. I recommend you upgrade to Vue 3.5.x to meet your needs for custom elements.
unplugin-vue-ce β
A vue plugin that extends vue's Custom Element capabilities (v-model, child style)
English | δΈζ
Feature β
- 𧩠It is a function extension of vue
- π Compatible with multiple bundled platformsοΌviteγwebpackοΌ
- β° Support v-model
- β‘ Support child style
Tips: β This plugin will inject the implementation code into the vue runtime, which is what I have to tell you. If you have any problems using it, please submit an issue
Install β
npm i unplugin-vue-ce -D
or
yarn add unplugin-vue-ce-D
or
pnpm add unplugin-vue-ce -D
Usage β
Tips: You need to enable the
customElement
option of@vitejs/plugin-vue
Vite
// vite.config.ts
import { defineConfig } from 'vite'
import { viteVueCE } from 'unplugin-vue-ce'
import vue from '@vitejs/plugin-vue'
import type { PluginOption } from 'vite'
export default defineConfig({
plugins: [
vue(),
viteVueCE() as PluginOption,
],
})
Rollup
// rollup.config.js
import { rollupVueCE } from '@nplugin-vue-ce'
export default {
plugins: [
rollupVueCE(),
],
}
Webpack
// webpack.config.js
module.exports = {
/* ... */
plugins: [
require('unplugin-vue-ce').webpackVueCE(),
],
}
Vue CLI
// vue.config.js
module.exports = {
configureWebpack: {
plugins: [
require('unplugin-vue-ce').webpackVueCE({}),
],
},
}
ESBuild
// esbuild.config.js
import { build } from 'esbuild'
import { esbuildVueCE } from 'unplugin-vue-ce'
build({
plugins: [esbuildVueCE()],
})
π― Support v-model β
view more details @unplugin-vue-ce/v-model
π Support the style of child components β
view more details @unplugin-vue-ce/sub-style
π» Support using web component as root component β
view more details @unplugin-vue-ce/ce-app