vue使用less设置全局变量

7,032 阅读1分钟

npm装包

//首选,安装 less 和 less-loader ,在项目目录下运行如下命令
npm install less less-loader --save
npm i sass-resources-loader

修改utils.js

if (loader) {
    if (loader == 'less') {
        loaders.push({
            loader: 'less-loader',
            options: Object.assign({}, loaderOptions, {
                sourceMap: options.sourceMap
            })
        }, {
            loader: 'sass-resources-loader',
            options: {
                // common.less 自己的公共变量路径
                resources: [path.resolve(__dirname, '../src/common/css/common.less')]
            }
        });
    } else {
        loaders.push({
            loader: loader + '-loader',
            options: Object.assign({}, loaderOptions, {
                sourceMap: options.sourceMap
            })
        })
    }
}
修改之后需要npm run dev重新启动

使用

common.less定义全局变量
@mainColor:red;

在组件中直接使用
.text{
    color:@mainColor;
}