vite中配置less,vue3中配置less
前言
如果赶时间请直接使用目录跳到解决问题的部分。
使用的项目使用vue脚手架生成。
npm init vue@latest
版本如下
"@vitejs/plugin-vue": "^5.0.4",
"vue": "^3.4.21"
由于近期在学less,心想如果不能将其应用到vue项目中,无异于纸上谈兵。于是立即用vue脚手架创建了一个新的vue项目,兴冲冲地安装上了less依赖,于是漫长之路开始了。
目的
需要强调的是,我们的目的是,在各个vue文件中,可以不引入全局less文件就能使用less变量。
过程
注意,这个是踩坑过程,不要跟着这个做。
安装依赖
cnpm install -D less less-loader
说实话这一部分也蛮坑的,不少博客写的都是--save。
vue add style-resources-loader
这一步卡了非常久,特意花时间去了解cmd命令行的网络代理。
接下来就众说纷纭了,有说只需要修改vue.config.js的↓
const path = require('path')
module.exports = {
pluginOptions: {
'style-resources-loader': {
preProcessor: 'less',
patterns: [
// 全局less变量存储路径
path.resolve(__dirname, './src/assets/css/base.less'),
]
}
}
}
有说要安装vue-cli-plugin-style-resources-loader这个依赖的↓
cnpm i -D vue-cli-plugin-style-resources-loader
还有的也是修改vue.config.js,不过我没试,如下图↓
除了少部分我没有尝试的之外,这些无一例外都没有作用。于是我开始思考。从
vue add style-resources-loader
这个命令我就开始奇怪,为什么新出现的是vue.config.js而不是修改vite.config.js。经过前面的尝试后,我脑中浮现一个猜测,那就是vue.config.js根本就没有起作用,因为我们用的构建工具是vitejs,而以前的vue不是,所以这些人的说法可能没有错,但是过时了。于是我开始寻找vite的解决方法,不出意外很快就解决了问题。
解决
首先确认我们是用vue脚手架创建项目的。
- 安装依赖
cnpm i less -D
走完第一步其实已经可以使用内嵌的less样式
<style lang="less" scoped>
@red: red;
.box{
.test{
height: 100px;
width: 100px;
background-color: @red;
}
}
</style>
- 修改vite.config.js,添加下面这段
css: {
preprocessorOptions: {
less: {
modifyVars: {
hack: 'true; @import "@/assets/less.less"'
},
javascriptEnabled: true
}
}
}
@众所周知对应src目录,只需要对应修改这个全局less的目录即可。
对应下面的代码修改即可,加上css那部分就行了。
import { fileURLToPath, URL } from 'node:url'
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
vue(),
],
resolve: {
alias: {
'@': fileURLToPath(new URL('./src', import.meta.url))
}
},
// 核心代码
css: {
preprocessorOptions: {
less: {
modifyVars: {
hack: 'true; @import "@/assets/less.less"'
},
javascriptEnabled: true
}
}
}
})
结语
没想到连less-loader也没有用上,前端变化太快确实是让人头疼。