亲测好用! 全局使用less 定义的变量 (vue)- 实现换肤等功能,解决@变量 提示undefined 问题

变量存储位置:src / style / variable.less

前言:

        在项目中, 需要换肤,或者想设有相同的css属性值时, 我们可以采用less的变量,快捷修改

        前提: 已经安装好了对应版本 的less 和less-loader

                 (建议安装固定匹配版本,要不容易出错)

"less": "^4.0.0", // 这是我的less版本
"less-loader": "^8.0.0",


安装命令:
npm i less@4.0.0 -S
npm i less-loader@8.0.0 -S

第一步: 安装sass-resources-loader

npm i sass-resources-loader
或 yarn add sass-resources-loader

第二部: 修改 vue.confing.js

const path = require('path')
function resolve (dir) {
  return path.join(__dirname, dir)
}

module.exports = {
  chainWebpack: config => {
    config.resolve.alias.set('@', resolve('src'))
    const oneOfsMap = config.module.rule('less').oneOfs.store
    oneOfsMap.forEach(item => {
      item
        .use('sass-resources-loader')
        .loader('sass-resources-loader')
        .options({
          // 一个变量文件用下面这个, 我的less变量存放在 src/style/variable.less
          // 这个可根据自己的变量存放位置更改
          resources: './src/style/variable.less'

          // 多个文件
          resources: ['./src/style/vars.scss', './src/style/mixins.scss']
        })
        .end()
    })
  }
}

第三步 : 代码使用、重启项目

定义

使用

 展示

 

嘎嘎好用 兄弟们 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue3中,要定义全局变量,可以使用插件vue-cli-plugin-style-resources-loader来实现。首先,需要安装依赖库yarn add vue-cli-plugin-style-resources-loader -D。接下来,在vue.config.js文件中进行配置,可以使用以下代码: ``` const path = require('path') module.exports = { pluginOptions: { 'style-resources-loader': { preProcessor: 'less', patterns: [path.resolve(__dirname, './src/styles/variables.less')] } } } ``` 然后,在src/styles目录下新建一个variables.less文件,定义全局变量,比如@warningColor: red;。最后,在需要使用全局变量的地方,可以在<style lang="less">标签中直接引用该变量,例如: ``` <style lang="less"> .wrap { color: @warningColor; } </style> ``` 这样就可以在Vue3中定义使用全局变量了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [【VUE - 工具 - LESS】03、vuecli3.0+使用less定义全局变量](https://blog.csdn.net/weixin_44402694/article/details/116655484)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [浏览器显示数据库中数据的条形图柱状图 前后端分离vue.js+spring boot 计算机软件工程课程设计毕业设计 ...](https://download.csdn.net/download/Amzmks/88275824)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值