欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue2中使用sass并配置全局的sass樣式變量的方法

 更新時(shí)間:2018年09月04日 10:10:36   作者:上善若水丶  
這篇文章主要介紹了vue2中使用sass并配置全局的sass樣式變量的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

Sass語(yǔ)言

      Sass是一種強(qiáng)大的css擴(kuò)展語(yǔ)言(css本身并不是一門語(yǔ)言),它允許你使用變量、嵌套規(guī)則、mixins、導(dǎo)入等css沒有但開發(fā)語(yǔ)言(如Java、C#、Ruby等)有的一些特性,并且完全兼容CSS語(yǔ)法。Sass有助于保持大型樣式表結(jié)構(gòu)良好。

      Sass有兩種語(yǔ)法。

      一種稱為SCSS,是一個(gè)CSS3語(yǔ)法的擴(kuò)充版本,也就是說(shuō),所有符合CSS3語(yǔ)法的樣式表也都是具有相同語(yǔ)法意義的SCSS文件,SCSS樣式表文件要以.scss擴(kuò)展名結(jié)尾。在vue中,我們可以使用<style lang="scss"></style>來(lái)標(biāo)志里面的內(nèi)容是以SCSS語(yǔ)法來(lái)書寫的。

      一種稱為SASS,是Sass以前的語(yǔ)法,它和python一樣,沒有{}大括號(hào)來(lái)標(biāo)志程序塊,而是以縮進(jìn)來(lái)標(biāo)志嵌套層級(jí);而且也不使用分號(hào),而是用換行符來(lái)分隔屬性。SASS樣式表文件要以.sass擴(kuò)展名結(jié)尾。在vue中,我們可以使用<style lang="sass"></style>來(lái)標(biāo)志里面的內(nèi)容是以SASS語(yǔ)法來(lái)書寫的。

在vue中使用樣式文件sass,如果每個(gè).vue文件都引入該樣式,build出來(lái)文件后,勢(shì)必會(huì)造成樣式的重復(fù),冗余,如果在main.js中全局引入一個(gè)scss文件,在其中定義變量在其他組件或者頁(yè)面中引用報(bào)變量未定義錯(cuò)誤,其他的樣式可以正常顯示,顯然是編譯的問題。那么,全局設(shè)置并加載樣式就顯得很有必要了!

首先,npm安裝好

 "sass-loader": "^6.0.7",
 "sass-resources-loader": "^1.3.3",

在build/webpack.base.conf.js中,在module的rules里添加

{
    test: /\.scss$/,
    loaders: ["style", "css", "sass"]
   }

然后在build/utils.js文件中加入如下代碼:

需要注意的是:我的全局樣式是放在src/common/sass/index.scss中的

 function resolveResouce(name) {
  return path.resolve(__dirname, '../src/common/sass/' + name);
 }
 function generateSassResourceLoader() {
  var loaders = [
   cssLoader,
   'postcss-loader',
   'sass-loader',
   {
    loader: 'sass-resources-loader',
    options: {
     //這是用到的sass文件,多個(gè)文件時(shí)用數(shù)組的形式傳入,這是帶有變量和mixin的scss文件
     resources: [resolveResouce('variable.scss'), resolveResouce('mixin.scss')] 注意這是我全局樣式的位置,個(gè)人不同,需做調(diào)整
    }
   }
  ];
  if (options.extract) {
   return ExtractTextPlugin.extract({
    use: loaders,
    fallback: 'vue-style-loader'
   })
  } else {
   return ['vue-style-loader'].concat(loaders)
  }
 }

最后,將該頁(yè)面下方的return部分,改成如下模樣

 return {
  css: generateLoaders(),
  postcss: generateLoaders(),
  less: generateLoaders('less'),
  //sass: generateLoaders('sass', { indentedSyntax: true }),
  //scss: generateLoaders('sass'),
  sass: generateSassResourceLoader(),
  scss: generateLoaders('sass')
   .concat(
    {
     loader: 'sass-resources-loader',
     options: {
      resources: path.resolve(__dirname, '../src/common/sass/index.scss') //注意這是我全局樣式的位置,個(gè)人不同,需做調(diào)整
     }
    }
   ),
  stylus: generateLoaders('stylus'),
  styl: generateLoaders('stylus')
 }

總結(jié)

以上所述是小編給大家介紹的vue2中使用sass并配置全局的sass樣式變量,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

最新評(píng)論