gpt4 book ai didi

vue中配置scss全局变量的步骤

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 35 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章vue中配置scss全局变量的步骤由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

  在写项目的过程中,如果用的是scss来编写样式代码,常常需要定义各种变量,例如主题色、主字号之类的,因此我们会把这些变量写到一个单独的_variable.scss文件内,但是每次都要在vue单文件内引入这些变量未免太繁琐了,所以有没有办法可以默认把变量文件作为全局文件进行引入呢?答案是肯定的,可以用下面的方法进行配置,可以根据当前使用的框架和环境来进行方法的选择.

  1、使用vue-cli(即vue-cli2)脚手架时

  1. 首先,需要安装一个loader,sass-resources-loader 。

?
1
npm install sass-resources-loader --save-dev

  2. 找到build文件夹下的utils.js文件,在文件内找到这段配置代码 。

?
1
2
3
4
5
6
7
8
9
return {
   css: generateLoaders(),
   postcss: generateLoaders(),
   less: generateLoaders( 'less' ),
   sass: generateLoaders( 'sass' , { indentedSyntax: true }),
   scss: generateLoaders( 'sass' ),
   stylus: generateLoaders( 'stylus' ),
   styl: generateLoaders( 'stylus' )
}

  3. 修改其中的scss项,改为 。

?
1
2
3
4
5
6
scss: generateLoaders( 'sass' ).concat({
    loader: 'sass-resources-loader' ,
    options:{
     resources:path.resolve(__dirname, '../src/styles/_variable.scss' )
    }
   })

  4. 重启项目,即可在其他文件内使用这些变量文件了 。

  2、使用@vue/cli(即vue-cli3)脚手架时

  1. 找到vue.config.js文件,如果没有的话,则自己在根目录新建一个即可 。

  2. 在文件内编写如下代码:

?
1
2
3
4
5
6
7
8
9
module.exports = {
  css: {
   loaderOptions: {
    sass: {
     data: `@import "@/styles/_variable.scss" ;`
    }
   }
  }
}

  3. 重启项目,即可使用 。

  注意:如果编写完以上代码,重启项目后出现这个错误:

?
1
Invalid options object. Sass Loader has been initialised using an options object that does not match the API schema.

  那么说明,你安装的sass-loader应该是V8的版本,可以在package.json中查看是否确实如此,如果的确是v8版本以上,则需要配置不同的写法,因为在V8中已经废除了data这个配置项,改为了prependData,具体可以在vue cli官网中看到此说明。【传送门】 。

vue中配置scss全局变量的步骤

   因此,我们需要将配置代码修改成如下样式:

?
1
2
3
4
5
6
7
css: {
   loaderOptions: {
     sass: {
       prependData: `@import "~@/styles/_variable.scss" ;`
     }
   }
}

  好了,重启一下项目,大功告成.

以上就是vue中配置scss全局变量的步骤的详细内容,更多关于vue配置scss全局变量的资料请关注我其它相关文章! 。

原文链接:https://www.cnblogs.com/happymental/p/12358167.html 。

最后此篇关于vue中配置scss全局变量的步骤的文章就讲到这里了,如果你想了解更多关于vue中配置scss全局变量的步骤的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com