vue2中使用sass并配置全局的sass樣式變量的方法
Sass語言
Sass是一種強大的css擴展語言(css本身并不是一門語言),它允許你使用變量、嵌套規(guī)則、mixins、導(dǎo)入等css沒有但開發(fā)語言(如Java、C#、Ruby等)有的一些特性,并且完全兼容CSS語法。Sass有助于保持大型樣式表結(jié)構(gòu)良好。
Sass有兩種語法。
一種稱為SCSS,是一個CSS3語法的擴充版本,也就是說,所有符合CSS3語法的樣式表也都是具有相同語法意義的SCSS文件,SCSS樣式表文件要以.scss擴展名結(jié)尾。在vue中,我們可以使用<style lang="scss"></style>來標志里面的內(nèi)容是以SCSS語法來書寫的。
一種稱為SASS,是Sass以前的語法,它和python一樣,沒有{}大括號來標志程序塊,而是以縮進來標志嵌套層級;而且也不使用分號,而是用換行符來分隔屬性。SASS樣式表文件要以.sass擴展名結(jié)尾。在vue中,我們可以使用<style lang="sass"></style>來標志里面的內(nèi)容是以SASS語法來書寫的。
在vue中使用樣式文件sass,如果每個.vue文件都引入該樣式,build出來文件后,勢必會造成樣式的重復(fù),冗余,如果在main.js中全局引入一個scss文件,在其中定義變量在其他組件或者頁面中引用報變量未定義錯誤,其他的樣式可以正常顯示,顯然是編譯的問題。那么,全局設(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文件,多個文件時用數(shù)組的形式傳入,這是帶有變量和mixin的scss文件
resources: [resolveResouce('variable.scss'), resolveResouce('mixin.scss')] 注意這是我全局樣式的位置,個人不同,需做調(diào)整
}
}
];
if (options.extract) {
return ExtractTextPlugin.extract({
use: loaders,
fallback: 'vue-style-loader'
})
} else {
return ['vue-style-loader'].concat(loaders)
}
}
最后,將該頁面下方的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') //注意這是我全局樣式的位置,個人不同,需做調(diào)整
}
}
),
stylus: generateLoaders('stylus'),
styl: generateLoaders('stylus')
}
總結(jié)
以上所述是小編給大家介紹的vue2中使用sass并配置全局的sass樣式變量,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue3使用Proxy實現(xiàn)數(shù)據(jù)監(jiān)聽的原因分析
在本篇文章里小編給大家整理的是一篇關(guān)于Vue3使用Proxy實現(xiàn)數(shù)據(jù)監(jiān)聽的原因分析內(nèi)容,有需要的朋友們可以跟著學(xué)習(xí)參考下。2021-11-11
Vue+Elementui el-tree樹只能選擇子節(jié)點并且支持檢索功能
這篇文章給大家介紹了Vue+Element UI el-tree樹只能選擇子節(jié)點并且支持檢索的文章,通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-12-12
詳解使用vue-cli腳手架初始化Vue項目下的項目結(jié)構(gòu)
這篇文章主要介紹了詳解使用vue-cli腳手架初始化Vue項目下的項目結(jié)構(gòu),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03
VUE + OPENLAYERS實現(xiàn)實時定位功能
本系列文章介紹一個簡單的實時定位示例,基于VUE + OPENLAYERS實現(xiàn)實時定位功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-09-09

