vue-cli建立的项目中途按需引入element-ui后webpack出警告

发布于 2022-09-05 09:38:52 字数 3183 浏览 17 评论 0

问题描述
项目一开始以vue-cli创建.开发一段时间后,按需引入element后报以下警告,但是可以正常使用

    e:\项目\efmweb_manage_frontEnd\efmweb_manage\node_modules\.0.28.4@css-loader\index.js?{"minimize":false,"sourceMap":false}!e:\项目\efmweb_manage_frontEnd\efmweb_manage\node_modules\.12.2.1@vue-loader\lib\style-compiler\index.js?{"vue":true,"id":"data-v-5e08ff16","scoped":false,"hasInlineConfig":false}!e:\项目\efmweb_manage_frontEnd\efmweb_manage\node_modules\.12.2.1@vue-loader\lib\selector.js?type=styles&index=0!e:\项目\efmweb_manage_frontEnd\efmweb_manage\src\index.vue
 warning  in E:/项目/efmweb_manage_frontEnd/efmweb_manage/~/.3.0.1@vue-style-loader/lib/listToStyles.js
There are multiple modules with names that only differ in casing.
This can lead to unexpected behavior when compiling on a filesystem with other case-semantic.
Use equal casing. Compare these module identifiers:
* E:\项目\efmweb_manage_frontEnd\efmweb_manage\node_modules\.3.0.1@vue-style-loader\lib\listToStyles.js
    Used by 1 module(s), i. e.
    E:\项目\efmweb_manage_frontEnd\efmweb_manage\node_modules\.3.0.1@vue-style-loader\lib\addStylesClient.js
* e:\项目\efmweb_manage_frontEnd\efmweb_manage\node_modules\.3.0.1@vue-style-loader\lib\listToStyles.js
    Used by 1 module(s), i. e.
    e:\项目\efmweb_manage_frontEnd\efmweb_manage\node_modules\.3.0.1@vue-style-loader\lib\addStylesClient.js

引入步骤/详细信息
step1:

npm i element-ui -S
npm install babel-plugin-component -D

step2:修改.babelrc
下图是element引入前后的.babelrc对比

clipboard.png

下图是element引入前后的package.json对比
clipboard.png

step3:
修改main.js,增加3行

import { Table, TableColumn } from 'element-ui'
Vue.use(Table);
Vue.use(TableColumn);

以下是整个main文件(去除与问题无关的部分)

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
//挂载浏览器全局js
import "@/js/global.js"
//按需挂载element-ui
import { Table, TableColumn } from 'element-ui'
Vue.use(Table);
Vue.use(TableColumn);
//挂载核心组件
import home from './index'
import router from './router'

Vue.config.productionTip = false;

/* eslint-disable no-new */
const vm=new Vue({
  el: '#root',
  router,
  template: '<home/>',
  components: { home }
});

我的尝试
觉得可能是webpack原因。之后私装了style-loader之类的 找到webpack.base.conf.js在下图处增加一个规则

clipboard.png
新增部分如下

{
   test: /\.css$/,
   loader: 'style-loader!css-loader'
},

然后webpack就不再抛出警告 而是抛出错误告诉我没有发现这个table.css之类的,然后无法运行项目
经查 可能是vue-loader不允许私装css加载器。。

我的期望
能正常使用element的前提下 webpack不抛出类似告警 从源头解决问题而不是简单的disable hint

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

带刺的爱情 2022-09-12 09:38:52
首先你得保证你的项目目录里不要出现中文。
element的样式需要单独引入,你引了了吗?
看报错情况像是
import { Table, TableColumn } from 'element-ui'
Vue.use(Table);
Vue.use(TableColumn);
但是这种写法应该是可以的,不然你试试
import ElementUI from 'element-ui'
Vue.use(ElementUI);
浮生面具三千个 2022-09-12 09:38:52

非常感谢楼上的回答,给了很多启示。问题目前已经解决。解决方案是删除node_module目录然后用npm install(而非cnpm)重装一次。但是解决方案看起来像是玄学问题。故而暂时不关闭 希望更多朋友回答一下

多情癖 2022-09-12 09:38:52

今天在看element-ui的按需加载问题,操作和楼主是一样的,但是我并不需要(无报错)在webpack.base.conf.js中添加新的loader规则,不管是按需加载前,还是按需加载后。我把自己的package文件简单对比了一下,楼主有的模块版本可以update,像是babel-loader,我近期的是7.1.1。

失眠症患者 2022-09-12 09:38:52

其实这个报错是你的项目css依赖和element-ui的css依赖发生了冲突,cnpm安装element-ui时候会自动帮你解决这个错误,npm安装element-ui会把错误报出来,你自行找一下项目哪里的css依赖发生了冲突吧,通常是 improt animate.css了和element-ui里的animate.css发生重复引入冲突,直接把improt animate.css换成link引入就行了

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文