element plus按需导入的坑

本文探讨了如何在Element Plus 2.1.8中使用unplugin-auto-import和unplugin-vue-components实现按需导入后,遇到的国际化配置、v-loading组件无法使用、messageBox样式问题以及遮罩层缺失的解决方案。作者提供了配置`ConfigProvider`和针对特定组件的AutoImport排除规则的建议。

element plus版本2.1.8,用了官网的方法,靠unplugin-auto-import(版本0.6.9)和unplugin-vue-components(版本0.18.5)实现按需导入后,碰到一些问题。

按需导入后实现国际化

因为element plus默认是英文,所以要转成中文。
此时,官网给了两个方法:
第一种,在main.js里添加【import ElementPlus from ‘element-plus’】等代码。别用,用了你就不是按需导入,变全部导入了。
第二种,ConfigProvider
官网链接:https://element-plus.gitee.io/zh-CN/guide/i18n.html#configprovider
写在app.vue里,拿个ConfigProvider组件把dom包起来。和上面的方法不同,ConfigProvider不会影响按需导入,经测试,打完的包确实没有异常变大。

按需导入后,v-loading不能用了

报错信息:
Can’t resolve ‘element-plus/es/components/loading-directive/style/css’
需要给AutoImport加个正则:

AutoImport({
        resolvers: [ElementPlusResolver({
          exclude: new RegExp(/^(?!.*loading-directive).*$/)
        })]
      })

按需导入后,messageBox样式错乱,遮罩层也没了

main.js里手动引入样式

import "element-plus/theme-chalk/el-message-box.css";// messageBox的样式
import "element-plus/theme-chalk/el-overlay.css";// 遮罩层样式
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值