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)系作者
  • 序言:七十年代末玄括,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子诵盼,更是在濱河造成了極大的恐慌惠豺,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件风宁,死亡現(xiàn)場離奇詭異洁墙,居然都是意外死亡,警方通過查閱死者的電腦和手機戒财,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進店門热监,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人饮寞,你說我怎么就攤上這事孝扛×泻穑” “怎么了?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵苦始,是天一觀的道長寞钥。 經(jīng)常有香客問我,道長陌选,這世上最難降的妖魔是什么理郑? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮咨油,結果婚禮上您炉,老公的妹妹穿的比我還像新娘。我一直安慰自己役电,他們只是感情好赚爵,可當我...
    茶點故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著法瑟,像睡著了一般冀膝。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上霎挟,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天畸写,我揣著相機與錄音,去河邊找鬼氓扛。 笑死枯芬,一個胖子當著我的面吹牛,可吹牛的內容都是我干的采郎。 我是一名探鬼主播千所,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼蒜埋!你這毒婦竟也來了淫痰?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤整份,失蹤者是張志新(化名)和其女友劉穎待错,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體烈评,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡火俄,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了讲冠。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瓜客。...
    茶點故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出谱仪,到底是詐尸還是另有隱情玻熙,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布疯攒,位于F島的核電站嗦随,受9級特大地震影響,放射性物質發(fā)生泄漏敬尺。R本人自食惡果不足惜称杨,卻給世界環(huán)境...
    茶點故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望筷转。 院中可真熱鬧,春花似錦悬而、人聲如沸呜舒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽袭蝗。三九已至,卻和暖如春般婆,著一層夾襖步出監(jiān)牢的瞬間到腥,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工蔚袍, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留乡范,地道東北人。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓啤咽,卻偏偏與公主長得像晋辆,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子宇整,可洞房花燭夜當晚...
    茶點故事閱讀 44,611評論 2 353

推薦閱讀更多精彩內容

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