当前位置: 首页 > news >正文

Vue3 Cli5按需导入ElementPlus

1、安装环境

node:16.20.0
vue:3.2.36
vue/cli:5.0.0
element-plus:2.2.25
element-plus/icons-vue:2.0.10
unplugin-auto-import:0.16.1 // 当前环境用这个包,不然会提示各种错误
unplugin-vue-components:0.25.0 // 当前环境用这个包,不然会提示各种错误

2、vue.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 = defineConfig({configureWebpack: {plugins: [AutoImport({resolvers: [ElementPlusResolver()]}),Components({resolvers: [ElementPlusResolver()]})]}
})

3、配置完后,重新运行npm run serve。会在根目录下生成auto-imports.d.ts和components.d.ts。

4、配置tsconfig.json。在include中新增以下两项

{"include": ["auto-imports.d.ts","components.d.ts"]
}

5、由于elementPlus的Icon如果按需引入的话,会破坏最终的使用方式。因此这里按照全局引入的形式使用

// main.ts
import * as ElementPlusIconsVue from '@element-plus/icons-vue'const app = createApp(App);
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {// @ts-ignoreapp.component(key, component)
}

6、到这里其实可以使用了,但是运行后样式会丢失,因此需要再main.ts中再引入样式文件

import 'element-plus/dist/index.css'

7、国际化,目前有三种引入方式。

7.1、第一种全局引入,但是需要全局导入element-plus。这会破坏按需引入。
7.2、在使用的每个组件中,导入locale。太麻烦了。
7.3、目前我在使用的,在App.vue中使用
<template><el-config-provider :locale="locale"><router-view/></el-config-provider>
</template>
<script lang='ts' setup>
import {reactive} from "vue";
// @ts-ignore
import zhCn from 'element-plus/dist/locale/zh-cn.mjs'
const {locale} = reactive({locale: zhCn
})
</script>

http://www.lryc.cn/news/288910.html

相关文章:

  • playwright自动化项目搭建
  • mysql字符集
  • Elasticsearch:聊天机器人、人工智能和人力资源:电信公司和企业组织的成功组合
  • [AIGC大数据基础] Flink: 大数据流处理的未来
  • 数据结构之线性表(一般的线性表)
  • uniapp安卓android离线打包本地打包整理
  • vmware安装centos8-stream
  • 使用HttpServletRequestWrapper解决web项目request数据流无法重复读取的问题
  • 从CNN ,LSTM 到Transformer的综述
  • Git学习笔记:1 基础命令详解
  • 【服务器】安装宝塔面板
  • 开源模型应用落地-业务优化篇(一)
  • 【遥感专题系列】影像信息提取之——基于专家知识的决策树分类
  • lqb日志08
  • SAP EXCEL上传如何实现指定读取某一个sheet页(ALSM_EXCEL_TO_INTERNAL_TABLE)
  • 奇怪问题说 - 测试篇
  • 中国新能源汽车持续跑出发展“加速度”,比亚迪迎来向上突破
  • chatGPT辅助写硕士毕业论文
  • 搭建nginx图片服务器
  • 大数据学习之Flink算子、了解DataStream API(基础篇一)
  • js中字符串string,遍历json/Object【匹配url、邮箱、电话,版本号,千位分割,判断回文】
  • 字符串和C预处理器
  • Ultraleap 3Di新建项目之给所有的Joint挂载物体
  • 关于session每次请求都会改变的问题
  • 【leetcode题解C++】150.逆波兰表达式求值 and 239.滑动窗口最大值 and 347.前k个高频元素
  • 【计网·湖科大·思科】实验三 总线型以太网的特性、集线器和交换机的区别、交换机的自学习算法
  • API设计模式:REST、GraphQL、gRPC与tRPC全面解析
  • C/C++ protobuf与json互转
  • Open CASCADE学习|圆柱螺旋线绘制原理探究
  • Python学习笔记--认识sys.argv