vue2中使用sass并配置全局的sass样式变量的方法

前端之家收集整理的这篇文章主要介绍了vue2中使用sass并配置全局的sass样式变量的方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

Sass语言

Sass是一种强大的css扩展语言(css本身并不是一门语言),它允许你使用变量、嵌套规则、mixins、导入等css没有但开发语言(如Java、C#、Ruby等)有的一些特性,并且完全兼容CSS语法。Sass有助于保持大型样式表结构良好。

Sass有两种语法。

一种称为SCSS,是一个CSS3语法的扩充版本,也就是说,所有符合CSS3语法的样式表也都是具有相同语法意义的SCSS文件,SCSS样式表文件要以.scss扩展名结尾。在vue中,我们可以使用来标志里面的内容是以SASS语法来书写的。

在vue中使用样式文件sass,如果每个.vue文件都引入该样式,build出来文件后,势必会造成样式的重复,冗余,如果在main.js中全局引入一个scss文件,在其中定义变量在其他组件或者页面中引用报变量未定义错误,其他的样式可以正常显示,显然是编译的问题。那么,全局设置并加载样式就显得很有必要了!

首先,npm安装好

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

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

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

css-loader','sass-loader',{ loader: 'sass-resources-loader',options: { //这是用到的sass文件,多个文件时用数组的形式传入,这是带有变量和mixin的scss文件 resources: [resolveResouce('variable.scss'),resolveResouce('mixin.scss')] 注意这是我全局样式的位置,个人不同,需做调整 } } ]; if (options.extract) { return ExtractTextPlugin.extract({ use: loaders,fallback: 'vue-style-loader' }) } else { return ['vue-style-loader'].concat(loaders) } }

最后,将该页面下方的return部分,改成如下模样

Syntax: true }),//scss: generateLoaders('sass'),sass: generateSassResourceLoader(),scss: generateLoaders('sass') .concat( { loader: 'sass-resources-loader',options: { resources: path.resolve(__dirname,'../src/common/sass/index.scss') //注意这是我全局样式的位置,个人不同,需做调整 } } ),stylus: generateLoaders('stylus'),styl: generateLoaders('stylus') }

总结

以上所述是小编给大家介绍的vue2中使用sass并配置全局的sass样式变量。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

原文链接:https://www.f2er.com/vue/30493.html

猜你在找的Vue相关文章