Laravel 中使用 Mix 配置 Element-plus 自动导入


Element-plus 是基于 Vue3 的响应式框架,在 Laravel 中使用 Laravel Mix 实现 Element-plus 的样式文件的自动导入,以此代替全局引入的方式,降低 CSS 文件的大小。

安装插件

在项目根目录下执行指令

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

如果你使用的是 Laravel Sail 环境,别忘记在命令前面加上 sail 前缀

修改 webpack.mix.js

修改 Laravel 项目的根目录 webpack.mix.js

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

mix.webpackConfig({
    plugins: [
        AutoImport({
            resolvers: [ElementPlusResolver({
                exclude: new RegExp(/^(?!.*loading-directive).*$/)
            })],
        }),
        Components({
            resolvers: [ElementPlusResolver()],
        }),
    ]
});

注意到其中有一段代码

exclude: new RegExp(/^(?!.*loading-directive).*$/)

这是用来解决自动导入后引发的 Cannot find module 'element-plus/es/components/loading-directive/style/css 错误,原理是通过正则表达式取消自动加载 loading-directive 样式,错误的引发原因未知。

Enjoy it

注释掉原先引入所有样式的代码,然后执行指令(如在配置前已经执行则需要终止后重新执行)

npm run watch-poll

你将发现你的应用仍然正常运行

参考资料

Element-plus 快速开始

How to include webpack plugins when using Laravel Mix? - Stack Overflow

vue3.x 项目使用element-plus 自动按需导入 使用v-loading报错 无法找到样式

你也可以在我的个人博客看到这篇文章:Laravel 中使用 Mix 配置 Element-plus 自动导入 | microven’s blog

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值