webpack+vue+sass项目中,sass提取全局引用

此文首发于 lijing0906.github.io

接近年底,工作没有那么忙,业余时间就比较多了,就想着把小demo整合到一起,自己搭建一个项目。 在网上找了两篇博客作为参考:在vue中使用sass的配置的方法vue引入sass全局变量

基础依赖包安装

安装sass-loader和node-sass(sass-loader依赖于node-sass)。-D是--save-dev的缩写,依赖包在开发环境和生产环境都需要;对应的-S是--save的缩写,只需在生产环境需要。

    $ cnpm i node-sass sass-loader -D
复制代码

webpack配置

在build文件夹下的webpack.base.conf.js的rules里面添加以下配置代码:

{
  test: /\.sass$/,
  loaders: ['style', 'css', 'sass']
}
复制代码

写sass样式

在App.vue文件中写上sass代码,测试配置是否成功。

<style lang="scss">
    $backgroundColor: #000;
    body{
        background-color: $backgroundColor;
    }
</style>
复制代码

启动项目看效果

重启项目(cnpm run dev)会发现页面背景色变成黑色了。 如图:

全局引用sass变量

全局样式如下图

在main.js中全局引入一个scss文件,然后在任何需要用到sass变量的文件中引用变量即可。
在其中定义变量在其他组件或者页面中引用报变量未定义错误,其他的样式可以正常显示,显然是编译的问题。

安装sass-resources-loader

    $ cnpm i sass-resources-loader -D
复制代码

修改sass配置

在 build 文件夹下找到 util.js 修改sass编译器loader的配置

    // 全局文件引入 当然只想编译一个文件的话可以省去这个函数
    function resolveResource(name) {
        return path.resolve(__dirname, '../src/assets/css/' + name);  //我把提取的样式放在src/assets/css下
    }
    function generateSassResourceLoader() {
        var loaders = [
            cssLoader,
            'sass-loader',
            {
                loader: 'sass-resources-loader',
                options: {
                    resources: [resolveResource('common.scss')]  // 多个文件时用数组的形式传入,单个文件时可以直接使用 path.resolve(__dirname, '../src/assets/css/common.scss'
                }
            }
        ];
        if (options.extract) {
            return ExtractTextPlugin.extract({  //要确保util.js有引入ExtractTextPlugin这个插件,通常都是有的
                use: loaders,
                fallback: 'vue-style-loader'
            })
        } else {
            return ['vue-style-loader'].concat(loaders)
        }
    }
复制代码

修改sass配置的调用为 generateSassResourceLoader()

return {
    css: generateLoaders(),
    postcss: generateLoaders(),
    less: generateLoaders('less'),
        // vue-cli默认sass配置
        // sass: generateLoaders('sass', { indentedSyntax: true }), 
        // scss: generateLoaders('sass'),
    // 新引入的sass-resources-loader
    sass: generateSassResourceLoader(),
    scss: generateSassResourceLoader(),
    stylus: generateLoaders('stylus'),
    styl: generateLoaders('stylus')
  }
复制代码

引入文件,重启项目

修改配置文件都需要重启项目。重启项目没有报错,全局样式生效

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值