Vue3项目中引入ElementUI使用详解

Vue3项目中引入 ElementUI

ElementUI是一个强大的PC端UI组件框架,它不依赖于vue,但是却是当前和vue配合做项目开发的一个比较好的ui框架,其包含了布局(layout),容器(container)等各类组件,基本上能满足日常网站的搭建开发。针对vue2和vue3都有对应的组件版本,本文主要介绍在vue3中如何引入使用ElementUI(vue3中升级为Element Plus)。

1.安装

vue3中使用如下命令通过 npm 安装 (本人项目使用的安装方式)

$ npm install element-plus --save

也可以使用其他的包管理起进行安装:

# Yarn
$ yarn add element-plus

# pnpm
$ pnpm install element-plus

2.引入

element-plus分为全局引入和按需引入两种方式,一般在工程项目中,由于全局引入会导致不必要的资源加载,为提升项目性能,建议进行按需引入。以下我们对两种引入方式进行介绍。

2.1 全局引入

全局引入就是在项目入口(main.ts)文件直接引入组件以及组件全部的样式文件;代码如下所示:

// main.ts
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')
2.2 按需引入

在vue3中按需引入ElementUI,需要使用其他的插件辅助,需要安装unplugin-vue-componentsunplugin-auto-import这两款插件;安装方法如下:

npm install -D unplugin-vue-components unplugin-auto-import

然后再vite或者webpack配置中添加相应的配置,如下所示:

vite
// vite.config.ts
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()],
    }),
  ],
})
Webpack
// webpack.config.js
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()],
    }),
  ],
}

若篇日志再vue.config.js中,导入方法相同:

const { defineConfig } = require('@vue/cli-service')
const AutoImport = require('unplugin-auto-import/webpack')
const Components = require('unplugin-vue-components/webpack')
const { ElementPlusResolver } = require('unplugin-vue-components/resolvers')

module.exports = defineConfig({
  configureWebpack: {
  	plugins: [
        AutoImport({
          resolvers: [ElementPlusResolver()],
        }),
        Components({
          resolvers: [ElementPlusResolver()],
        }),
      ],
  }
})

3.使用

引入完毕之后,我们可进行按需引入需要使用的组件,使用方法如下,引入input组件和button组件

<template>
  <div>
    <el-input class="input" v-model="input" type="file" placeholder="Please input" />
    <el-button class="button" type="primary">文件处理</el-button>
  </div>
</template>

<script>
  import { ElButton, ElInput } from 'element-plus'
  import { ref } from 'vue'
  
  export default {
    components: { ElButton,ElInput },
  }

</script>
<style scoped>
.input {
  display: inline;
  margin: 20px 30px;
}
.button {
  width: 90px;
}
</style>

效果如下:

在这里插入图片描述

此外ElementUI中还有其他组件,基本能满足开发需求,提升开发效率,详情请见官网:ElementUI

注:在vue3中,由于vite打包拥有良好的性能,本文使用的示例为vite打包方式,同时建议使用其他包最新的支持版本进行开发。

### 如何在Vue3项目引入ElementUI 要在Vue3项目中成功引入ElementUI,可以按照以下方法操作: #### 安装依赖 首先,在终端运行命令安装 `element-plus` 和其对应的样式文件。由于 Vue3 的版本更新,推荐使用 `element-plus` 而不是旧版的 `element-ui`。 ```bash npm install element-plus --save ``` 此过程会自动下载并保存到项目的依赖列表中[^2]。 #### 配置 main.js 文件 接着需要修改 `main.js` 文件来全局注册 ElementPlus 组件以及加载所需的 CSS 样式。以下是具体的实现方式: ```javascript // 导入 Vue 库和 Element Plus 主包及其样式表 import { createApp } from &#39;vue&#39;; import App from &#39;./App.vue&#39;; import ElementPlus from &#39;element-plus&#39;; // 引入组件库 import &#39;element-plus/dist/index.css&#39;; // 引入样式资源 const app = createApp(App); app.use(ElementPlus); // 使用 Element Plus 插件 app.mount(&#39;#app&#39;); // 将应用挂载至 DOM 中指定节点上 ``` 通过以上设置即可完成对整个框架的支持[^4]。 #### 按需加载 (Optional) 如果希望减少打包体积,则可以选择按需加载的方式只引入需要用到的部分功能模块而不是全部内容。这通常借助于工具如 babel-plugin-component 来达成目标: 1. **安装插件** ```bash npm install babel-plugin-component -D ``` 2. **调整 .babelrc 或者 babel.config.js** 如果采用 `.babelrc` 形式的配置文件则添加如下字段;如果是 ES Module 方式的 Babel Config 则相应地扩展 plugins 数组部分。 ```json { "plugins": [ ["component", {"libraryName": "element-plus", "styleLibraryName": "theme-chalk"}] ] } ``` 之后就可以单独导入各个控件而不必担心多余的代码被包含进来[^3]。 例如仅需按钮组件时可这样写: ```javascript import { Button } from &#39;element-plus&#39;; import &#39;element-plus/lib/theme-chalk/button.css&#39;; export default { components: { ElButton: Button }, }; ``` #### 总结 综上所述,无论是整体还是局部引入 Element UI 至 Vue3 工程都非常简便快捷,并且能够极大地提升开发效率与用户体验质量[^1]。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值