Vue引入sass并配置全局變量
引入sass
首先使用官方提供的腳手架vue-cli
進(jìn)行搭建框架,這里就不做說明了滨巴,查閱官網(wǎng)即可优烧。
等安裝完所有依賴后沛豌,安裝sass的依賴包:
npm install --save-dev sass-loader
//sass-loader依賴于node-sass
npm install --save-dev node-sass
然后在build文件夾下的webpack.base.conf.js
的rules里面添加配置:
{
test: /\.sass$/,
loaders: ['style', 'css', 'sass']
}
然后添加csslang
屬性夭咬。注意啃炸,這里是scss,而且css文件的后綴也是scss:
<style lang="scss"></style>
最后需要重新編譯一下項(xiàng)目卓舵,否則沒有效果南用。
$ npm run dev
現(xiàn)在就可以隨意的使用sass了,這時(shí)候會(huì)發(fā)現(xiàn)如果我想定義幾個(gè)變量進(jìn)行全局使用掏湾,好像只能在頁面中通過@import
來引入裹虫,這顯然不夠優(yōu)雅,可以這樣解決融击。
配置sass全局變量
有一個(gè)babel插件可以完美的解決這個(gè)問題:sass-resources-loader
可以訪問sass資源任何一個(gè)需要訪問的sass模塊恒界。所以,可以使用共享變量和混合所有SASS樣式砚嘴,而不去每個(gè)文件都引用十酣。
首先進(jìn)行插件安裝:
npm install --save-dev sass-resources-loader
然后在 build 文件夾下找到 util.js
修改sass編譯器loader的配置,直接把下面的代碼復(fù)制進(jìn)去即可:
// 全局文件引入 當(dāng)然只想編譯一個(gè)文件的話可以省去這個(gè)函數(shù)
function resolveResource(name) {
return path.resolve(__dirname, '../src/style/' + name);
}
function generateSassResourceLoader() {
var loaders = [
cssLoader,
'sass-loader',
{
loader: 'sass-resources-loader',
options: {
// 多個(gè)文件時(shí)用數(shù)組的形式傳入际长,單個(gè)文件時(shí)可以直接使用 path.resolve(__dirname, '../static/style/common.scss'
resources: [resolveResource('theme.scss')]
}
}
];
if (options.extract) {
return ExtractTextPlugin.extract({
use: loaders,
fallback: 'vue-style-loader'
})
} else {
return ['vue-style-loader'].concat(loaders)
}
}
將默認(rèn)的sass配置改為 generateSassResourceLoader()
耸采。
return {
css: generateLoaders(),
postcss: generateLoaders(),
less: generateLoaders('less'),
// vue-cli默認(rèn)sass配置
// sass: generateLoaders('sass', { indentedSyntax: true }),
// scss: generateLoaders('sass'),
// 新引入的sass-resources-loader
sass: generateSassResourceLoader(),
scss: generateSassResourceLoader(),
stylus: generateLoaders('stylus'),
styl: generateLoaders('stylus')
}
改完配置后重啟服務(wù)就可以在theme.scss
里定義全局變量并在頁面中引用了。
需要注意的是工育,scss里的變量是$
開頭虾宇,而less里的變量是@
開頭。比如我想定義一個(gè)項(xiàng)目的主色調(diào)變量如绸,我可以在theme.scss
里這樣定義:
$c-primary: #fd7a00;
$theme-blue: #3296fa;
$theme-red: #da3838;
引用變量的時(shí)候直接引用變量名即可嘱朽。