docs/en-US/guide/quickstart.md
This section describes how to use Element Plus in your project.
If you don’t care about the bundle size so much, it’s more convenient to use full import.
import { createApp } from 'vue'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import App from './App.vue'
const app = createApp(App)
app.use(ElementPlus)
app.mount('#app')
If you use volar, please add the global component type definition to compilerOptions.types in tsconfig.json.
{
"compilerOptions": {
// ...
"types": ["element-plus/global"]
}
}
You need to use an additional plugin to import components you used.
First you need to install unplugin-vue-components and unplugin-auto-import.
::: code-group
$ npm install -D unplugin-vue-components unplugin-auto-import
$ yarn add -D unplugin-vue-components unplugin-auto-import
$ pnpm install -D unplugin-vue-components unplugin-auto-import
:::
Then add the code below into your Vite or Webpack config file.
::: code-group
import { defineConfig } from 'vite'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
export default defineConfig({
// ...
plugins: [
// ...
AutoImport({
resolvers: [ElementPlusResolver()],
}),
Components({
resolvers: [ElementPlusResolver()],
}),
],
})
const AutoImport = require('unplugin-auto-import/webpack')
const Components = require('unplugin-vue-components/webpack')
const { ElementPlusResolver } = require('unplugin-vue-components/resolvers')
module.exports = {
// ...
plugins: [
AutoImport({
resolvers: [ElementPlusResolver()],
}),
Components({
resolvers: [ElementPlusResolver()],
}),
],
}
:::
For more bundlers (Rollup, Vue CLI) and configs please reference unplugin-vue-components and unplugin-auto-import.
For Nuxt users, you only need to install @element-plus/nuxt.
::: code-group
$ npm install -D @element-plus/nuxt
$ yarn add -D @element-plus/nuxt
$ pnpm install -D @element-plus/nuxt
:::
Then add the code below into your config file.
export default defineNuxtConfig({
modules: ['@element-plus/nuxt'],
})
Refer to the docs for how to configure it.
Element Plus provides out of box Tree Shaking functionalities based on ES Module.
But you need install unplugin-element-plus for style import. And refer to the docs for how to configure it.
<template>
<el-button>I am ElButton</el-button>
</template>
<script setup lang="ts">
import { ElButton } from 'element-plus'
</script>
import { defineConfig } from 'vite'
import ElementPlus from 'unplugin-element-plus/vite'
export default defineConfig({
// ...
plugins: [ElementPlus()],
})
We provide a Vite Template.
For Nuxt users we have a Nuxt Template.
For Laravel users we have a Laravel Template.
When registering Element Plus, you can pass a global config object with size and
zIndex to set the default size for form components, and zIndex for
popup components, the default value for zIndex is 2000.
Full import:
import { createApp } from 'vue'
import ElementPlus from 'element-plus'
import App from './App.vue'
const app = createApp(App)
app.use(ElementPlus, { size: 'small', zIndex: 3000 })
On-demand:
<template>
<el-config-provider :size="size" :z-index="zIndex">
<app />
</el-config-provider>
</template>
<script setup lang="ts">
import { ElConfigProvider } from 'element-plus'
const zIndex = 3000
const size = 'small'
</script>
We can also use Nuxt.js. Please refer to Element Plus Nuxt.js starter template for more details.
You can bootstrap your project from now on. For each components usage, please refer to the individual component documentation.