没有合适的资源?快使用搜索试试~ 我知道了~
首页vue2中使用sass并配置全局的sass样式变量的方法
Sass语言 Sass是一种强大的css扩展语言(css本身并不是一门语言),它允许你使用变量、嵌套规则、mixins、导入等css没有但开发语言(如Java、C#、Ruby等)有的一些特性,并且完全兼容CSS语法。Sass有助于保持大型样式表结构良好。 Sass有两种语法。 一种称为SCSS,是一个CSS3语法的扩充版本,也就是说,所有符合CSS3语法的样式表也都是具有相同语法意义的SCSS文件,SCSS样式表文件要以.scss扩展名结尾。在vue中,我们可以使用<style lang="scss"></style>来标志里面的内容是以SCSS语法来书写的
资源详情
资源评论
资源推荐

vue2中使用中使用sass并配置全局的并配置全局的sass样式变量的方法样式变量的方法
Sass语言语言
Sass是一种强大的css扩展语言(css本身并不是一门语言),它允许你使用变量、嵌套规则、mixins、导入等css没有但
开发语言(如Java、C#、Ruby等)有的一些特性,并且完全兼容CSS语法。Sass有助于保持大型样式表结构良好。
Sass有两种语法。有两种语法。
一种称为SCSS,是一个CSS3语法的扩充版本,也就是说,所有符合CSS3语法的样式表也都是具有相同语法意义的
SCSS文件,SCSS样式表文件要以.scss扩展名结尾。在vue中,我们可以使用<style lang="scss"></style>来标志里面的内容是以
SCSS语法来书写的。
一种称为SASS,是Sass以前的语法,它和python一样,没有{}大括号来标志程序块,而是以缩进来标志嵌套层级;而且
也不使用分号,而是用换行符来分隔属性。SASS样式表文件要以.sass扩展名结尾。在vue中,我们可以使用<style lang="sass">
</style>来标志里面的内容是以SASS语法来书写的。
在vue中使用样式文件sass,如果每个.vue文件都引入该样式,build出来文件后,势必会造成样式的重复,冗余,如果在
main.js中全局引入一个scss文件,在其中定义变量在其他组件或者页面中引用报变量未定义错误,其他的样式可以正常显
示,显然是编译的问题。那么,全局设置并加载样式就显得很有必要了!
首先,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文件,多个文件时用数组的形式传入,这是带有变量和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部分,改成如下模样
return {
css: generateLoaders(),
postcss: generateLoaders(),
less: generateLoaders('less'),
//sass: generateLoaders('sass', { indentedSyntax: true }),
//scss: generateLoaders('sass'),
sass: generateSassResourceLoader(),
scss: generateLoaders('sass')

















安全验证
文档复制为VIP权益,开通VIP直接复制

评论0