vue3+view-ui-plus+vite+less 实现自定义iview样式

首先是结论:

"less": "^2.7.3",

"less-loader": "^4.1.0",

vite.config.js

javascript 复制代码
resolve: {
      alias: {
        // 设置路径
        '~': path.resolve(__dirname, './'),
        // 设置别名
        '@': path.resolve(__dirname, './src')
      },
      extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']
    },

'~': path.resolve(__dirname, './'),

自定义文件 \src\assets\scss\view-design.less

javascript 复制代码
@import '~/node_modules/view-ui-plus/src/styles/index.less';

// Here are the variables to cover, such as:
@primary-color: #0066FE;
@link-hover-color:#4C94FF;
@text-color: #303133;

@import '~/node_modules/view-ui-plus/src/styles/index.less';

如果没代理 ~ 就是./

@import './node_modules/view-ui-plus/src/styles/index.less';

main.js 中引入

javascript 复制代码
import './assets/scss/view-design.less'

分享解决过程

如果按照官网的会报错

@import '~view-ui-plus/src/styles/index.less';

vite\] Internal server error: \[less\] '\~view-ui-plus/src/styles/index.less' wasn't found. Tried 暂时没找到什么原因,网上百度的方法全试了,包括以下全没用 1️⃣ 改less版本 2️⃣ ![](https://i-blog.csdnimg.cn/direct/dbe8c60875ec4c2ba3f64a8999cc9d48.png) 3️⃣ ```javascript css: { preprocessorOptions: { less: { modifyVars: { hack: 'true; @import "@/assets/less.less"' }, javascriptEnabled: true } } } ``` 最后我终于找到一篇文章让把 @import '\~iview/src/styles/index.less'; 改为 @import '\~view-design/dist/styles/iview.css'; 这个改了也没用,但是给我启发了,我改成 @import '\~/node_modules/view-ui-plus/src/styles/index.less'; 终于正常啦!

相关推荐
WYiQIU3 小时前
11月面了7.8家前端岗,兄弟们12月我先躺为敬...
前端·vue.js·react.js·面试·前端框架·飞书
谢尔登3 小时前
简单聊聊webpack摇树的原理
运维·前端·webpack
娃哈哈哈哈呀3 小时前
formData 传参 如何传数组
前端·javascript·vue.js
zhu_zhu_xia4 小时前
vue3+vite打包出现内存溢出问题
前端·vue
tsumikistep4 小时前
【前后端】接口文档与导入
前端·后端·python·硬件架构
行走的陀螺仪5 小时前
.vscode 文件夹配置详解
前端·ide·vscode·编辑器·开发实践
2503_928411565 小时前
11.24 Vue-组件2
前端·javascript·vue.js
Bigger6 小时前
🎨 用一次就爱上的图标定制体验:CustomIcons 实战
前端·react.js·icon
谢尔登6 小时前
原来Webpack在大厂中这样进行性能优化!
前端·webpack·性能优化
cypking7 小时前
Vue 3 + Vite + Router + Pinia + Element Plus + Monorepo + qiankun 构建企业级中后台前端框架
前端·javascript·vue.js