webpack + vue 全局共享使用less變量的解決方案

vue-cli生成的工程下,樣式使用了less語言,其中定義了一些全局變量,比如常用顏色,便于樣式切換。

//theme.less

@main: #fff;
@sub: #fff;
@border: #fff;
@grey: #fff;

但是Vue單文件組建內,less變量不能共享和繼承。
每個文件都要@import一遍也挺麻煩的。

不完美解決方案如下:

在./build/utils.js中
首先添加getLessVariables方法

....
function getLessVariables(file) {
  var themeContent = fs.readFileSync(file, 'utf-8')
  var variables = {}
  themeContent.split('\n').forEach(function (item) {
    if (item.indexOf('//') > -1 || item.indexOf('/*') > -1) {
      return
    }
    var _pair = item.split(':')
    if (_pair.length < 2) return;
    var key = _pair[0].replace('\r', '').replace('@', '')
    if (!key) return;
    var value = _pair[1].replace(';', '').replace('\r', '').replace(/^\s+|\s+$/g, '')
    variables[key] = value
  })
  return variables
}
....

然后給less-loader配置config

function generateLoaders(loader, loaderOptions) {
  ....
  return{
    ....
    less: generateLoaders('less', {
      modifyVars: getLessVariables('./src/style/theme.less')
    }),
    ....
  }
  ...
}

這樣就能做到全局共享一個theme.less文件里的變量了。

但是
這個方法并不能實現(xiàn)熱更新,修改theme后需要手動重啟npm run dev

提前把變量都寫好吧

完美解決方案如下:

使用sass的sass-resources-loader,也可以兼容less

./build/utils.jsexports.cssLoaders = function (options) { ... }中添加generateLessResourceLoader方法

function generateLessResourceLoader() {
    var loaders = [
      cssLoader,
      'less-loader',
      {
        loader: 'sass-resources-loader',
        options: {
          resources: [
            path.resolve(__dirname, '../src/style/theme.less'), 
            path.resolve(__dirname, '../src/style/mixins.less')
          ]
        }
      }
    ];
    if (options.extract) {
      return ExtractTextPlugin.extract({
        use: loaders,
        fallback: 'vue-style-loader'
      })
    } else {
      return ['vue-style-loader'].concat(loaders)
    }
  }

然后把下邊的

less: generateLoaders(),

替換成

less: generateLessResourceLoader('less'),

即可

這個方法可以完美實現(xiàn)全局less變量共享,和修改變量后的熱重載。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • 原文http://www.cnblogs.com/libin-1/p/6596810.html 版本號 vue-c...
    tengrl閱讀 3,875評論 0 0
  • GitChat技術雜談 前言 本文較長,為了節(jié)省你的閱讀時間,在文前列寫作思路如下: 什么是 webpack,它要...
    蕭玄辭閱讀 12,892評論 7 110
  • 在現(xiàn)在的前端開發(fā)中,前后端分離、模塊化開發(fā)、版本控制、文件合并與壓縮、mock數(shù)據等等一些原本后端的思想開始...
    Charlot閱讀 5,659評論 1 32
  • 一個不錯的預見,轉發(fā)給大家:摘自朋友圈縱觀中國發(fā)展大勢,2017年將是偉大而又轉折的一年,那么2017年將會發(fā)生哪...
    tgg2017閱讀 243評論 0 0
  • 身邊很多人都存在這樣一種觀念,我現(xiàn)在的讀書學習是為了以后能有一份好的工作,賺很多的錢,然后讓自己的家庭走出貧窮。這...
    小人丑閱讀 1,354評論 0 1

友情鏈接更多精彩內容