vue2中使用sass并配置全局的sass樣式變量的方法
Sass語言
Sass是一種強(qiáng)大的css擴(kuò)展語言(css本身并不是一門語言),它允許你使用變量、嵌套規(guī)則、mixins、導(dǎo)入等css沒有但開發(fā)語言(如Java、C#、Ruby等)有的一些特性,并且完全兼容CSS語法。Sass有助于保持大型樣式表結(jié)構(gòu)良好。
Sass有兩種語法。
一種稱為SCSS,是一個CSS3語法的擴(kuò)充版本,也就是說,所有符合CSS3語法的樣式表也都是具有相同語法意義的SCSS文件,SCSS樣式表文件要以.scss擴(kuò)展名結(jié)尾。在vue中,我們可以使用<style lang="scss"></style>
來標(biāo)志里面的內(nèi)容是以SCSS語法來書寫的。
一種稱為SASS,是Sass以前的語法,它和python一樣,沒有{}大括號來標(biāo)志程序塊,而是以縮進(jìn)來標(biāo)志嵌套層級;而且也不使用分號,而是用換行符來分隔屬性。SASS樣式表文件要以.sass擴(kuò)展名結(jié)尾。在vue中,我們可以使用<style lang="sass"></style>
來標(biāo)志里面的內(nèi)容是以SASS語法來書寫的。
在vue中使用樣式文件sass,如果每個.vue文件都引入該樣式,build出來文件后,勢必會造成樣式的重復(fù),冗余,如果在main.js中全局引入一個scss文件,在其中定義變量在其他組件或者頁面中引用報(bào)變量未定義錯誤,其他的樣式可以正常顯示,顯然是編譯的問題。那么,全局設(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)文章
從Vue到Postman全面驗(yàn)證API接口跨域問題解決
我們都知道跨域是同源策略導(dǎo)致的,域名不同、協(xié)議不同、端口號不同任意一種情況都會導(dǎo)致跨域,這篇文章主要介紹了從Vue到Postman全面驗(yàn)證API接口跨域問題,需要的朋友可以參考下2024-08-08vue+element-ui:使用el-dialog時彈框不出現(xiàn)的解決
這篇文章主要介紹了vue+element-ui:使用el-dialog時彈框不出現(xiàn)的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10Vue自定義指令實(shí)現(xiàn)checkbox全選功能的方法
下面小編就為大家分享一篇Vue自定義指令實(shí)現(xiàn)checkbox全選功能的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02不依任何賴第三方,單純用vue實(shí)現(xiàn)Tree 樹形控件的案例
這篇文章主要介紹了不依任何賴第三方,單純用vue實(shí)現(xiàn)Tree 樹形控件的案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09vue中的事件加判斷條件如何進(jìn)行選擇性點(diǎn)擊
這篇文章主要介紹了vue中的事件加判斷條件如何進(jìn)行選擇性點(diǎn)擊方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03基于vue-cli搭建多模塊且各模塊獨(dú)立打包的項(xiàng)目
這篇文章主要介紹了基于vue-cli搭建多模塊且各模塊獨(dú)立打包的項(xiàng)目,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-06-06vue2+elementui進(jìn)行hover提示的使用
本文主要介紹了vue2+elementui進(jìn)行hover提示的使用,主要分為外部和內(nèi)部,具有一定的參考價值,感興趣的可以了解一下2021-11-11