vue项目中使用scss

这篇具有很好参考价值的文章主要介绍了vue项目中使用scss。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


一、安装使用scss

1. 安装 scss

npm install scss --save

2. 安装 node-sass 和 sass-loader

sass-loader:把 sass编译成css
sass-loader:nodejs环境中将sass转css
提示:限制 node-sass,sass-loader 版本号,防止默认安装的版本号过高

npm i sass-loader@7.3.1 -D
npm i node-sass@4.14.1 -D

版本对应关系:
vue引入scss,vue,scss,vue.js,scss,javascript

3. 配置 webpack.base.conf.js 文件

提示:在 build 文件夹目录下 webpack.base.conf.js 文件中,找到 rules 添加以下代码

rules: [
  {
    test: /\.scss$/,
    loaders: ['style', 'css', 'sass']
  },
]

4. 组件中使用 scss

提示:在组件中style标签上添加属性 lang="scss",保存运行。

<style lang="scss">
#app {
  background: $color;
}
</style>

二、设置scss变量

1. 使用 sass-resources-loader 实现全局变量

安装 sass-resources-loader

cnpm install sass-resources-loader --save

2. 新建一个 public.scss 文件

在src目录下的assets文件夹里面新建一个public.scss文件,用于存放所有的公共变量。

3. 根目录下找到 build 下的 utils.js 文件

提示:resources里写 scss(公共变量文件) 路径

scss: generateLoaders('sass')
// 改为:
scss: generateLoaders('sass').concat({
  loader: 'sass-resources-loader',
  options: {
    resources: path.resolve(__dirname, '../src/assets/public.scss') // 指定单个文件
    // resources: [path.resolve(__dirname, '../src/assets/public.scss'),path.resolve(__dirname, '../src/assets/public.scss')] // 指定多个文件
    // 将匹配文件夹和子目录中的所有文件或路径数组
    // resources: path.resolve(__dirname, '../src/assets/scss/**/*.scss') // 指定单个文件夹和子目录中的所有文件
    // resources: [path.resolve(__dirname, '../src/assets/scss/**/*.scss'),path.resolve(__dirname, '../src/assets/scss/**/*.scss')] // 指定多个文件夹和子目录中的所有文件
  }
}),

4. 运行项目

重新npm run dev ,组件中就可以使用全局变量了。

三、常用全局变量

1. 设置变量

在全局变量文件里面写入变量($),混合(@mixin,括号里面为默认值,可有可无),继承(%)等语法。

// 变量
$color: #ff0;
$bac_color: #222;
$bac-color: #111;

.main {
  color: $color;
  background: $bac_color; /*$bac_color被$bac-color覆盖*/
}

// 混合
@mixin borderRadius($num: 8px) {
  color: $color;
  border-radius: $num;
}

// 继承
%cricle {
  width: 50px;
  height: 50px;
  background: red;
  border-radius: 50%;
}

2. 使用变量

在组建中使用变量($+变量名),混合(@include),继承(@extend)。

.div{
  // 变量
  background: $color;
  // 混合
  @include borderRadius(20px); /*()不传值用默认值8px*/
  // 继承
  @extend %cricle;
}

四、使用全局变量

1. 变量

1、变量以 $ 开头,用来存储一些在css中需要复用的参数;
2、变量存在作用域,内部声明的变量无法在外面使用,外部如需引用内部的变量,可在变量值的后面添加!global声明;
3、变量名中,中划线等同下划线,值会被第二次定义的变量覆盖。
scss代码

$color = #333;
$bac_color = #222;
$bac-color = #111;

.main {
  color: $color;
  background: $bac_color; /*$bac_color被$bac-color覆盖*/
}
/*编译后:*/
.main{
    color : #333;
    background: #111;
}

2. 嵌套

nav {
  ul {list-style: none;}
  li { display: inline-block; }
}
/*编译后:*/
nav ul{list-style: none;}
nav li{display: inline-block;}

3. 引入

1、scss通过 @import 可以把多个文件结合到一起;
2、以 _开头命名的文件不会直接生成为CSS文件,只在使用@import指令的位置被导入;
3、可全局引入或局部引入;
4、scss中引入片段时,可以缺省文件扩展名;
4、css原生的@import会通过额外的HTTP请求获取引入的样式片段,而scss的@import则会直接将这些引入的片段合并至当前CSS文件,并且不会产生新的HTTP请求。

/*_one.scss*/
nav {
  ul {list-style: none;}
  li { display: inline-block; }
}
/*two.scss*/
@import '_one' /*全局导入,缺省后缀*/

.main{
    @import '_one'/*局部导入*/
    color : #333;
    background: #111;
}

4. 混合

1、通过 @mixin 定义一个类或方法,在其它位置通过 @include 引用这个类或方法
2、@mixin 如果没有调用,不会被渲染
3、多个参数时,传参指定参数的名字,可以不用考虑传入的顺序

@mixin border-radius($radius:5px) {  /*设置默认值为5px*/
   border-radius: $radius;
   -ms-border-radius: $radius;
   -moz-border-radius: $radius;
   -webkit-border-radius: $radius;
}
.box {
  @include border-radius(); /*未传参数,默认值为5px*/
}
.box1 {
  @include border-radius(10px); /*传入参数,值为10px*/
}
/*编译后:*/
.box {
   border-radius: 5px;
   -ms-border-radius: 5px;
   -moz-border-radius: 5px;
   -webkit-border-radius: 5px;
}
.box1 {
   border-radius: 10px;
   -ms-border-radius:10px;
   -moz-border-radius: 10px;
   -webkit-border-radius:10px;
}

5. 继承

1、使用%定义一个被继承的样式,它本身不起作用,只用于被其他人继承
2、样式如果没有被继承,不会输出到最终生成的CSS文件
3、注意,不能继承 @extend .box .main 这种连续组合的类,应该写为
@extend .box, .main

%err-color {
    color:red;
}

.errBox{
    @extend %err-color;
    padding: 10px;
}
.errBox2{
    @extend %err-color;
    padding: 5px;
}
/*编译后:*/
.errBox, .errBox2{
    color:red;
}
.errBox{
    padding: 10px;
}
.errBox2{
    padding: 5px;
}

6. if / else / each / for

1、@if 和 @else

@if 条件为真 {
  //code
} @else {
  //code
}

2、 @each
遍历变量所存在的所有数据。

@each $color in red, green, yellow, blue {
  .p_#{$color} { /*插值,第七点会讲到*/
    background-color: #{$color};
  }
}
/*编译后:*/
.p_red { background-color: red; }
.p_green { background-color: green; }
.p_yellow { background-color: yellow; }
.p_blue { background-color: blue; }

3、@for循环
(1) 关键字 through 表示包括终点值这个数,
(2) 关键字 to 不包括终点值这个数。

@for $i from 1 through 3 { /*through  包括3这个终点值*/
  .item-#{$i} { 
     width: 2px * $i;
   }
}
/*编译后:*/
.item-1 {
  width: 2px;
}
.item-2 {
  width: 4xp;
}
.item-3 {
  width: 6px;
}

7. 其他(作为变量使用)

1、插值
一般我们定义的变量都为属性值,可直接使用,但是如果变量作为属性名称或在某些特殊情况下则必须要以 #{$XXX} 形式使用。

如下,变量作为属性名的情况使用插值的形式使用

@each $color in red, green, yellow, blue {
  .p_#{$color} { /*插值,第七点会讲到*/
    background-color: #{$color};
  }
}

$box_w: 100px;
.box {
	width: calc(100% - #{$box_w});
}
$static_imgUrl:"/static";
div{
  background: #fff url($static_imgUrl+"/images/login/background.jpg") no-repeat center center;
}

2、注释
(1) 使用//注释的内容编译后不存在
(2) 使用/* */注释的内容编译后会存在css文件中文章来源地址https://www.toymoban.com/news/detail-584319.html

到了这里,关于vue项目中使用scss的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue项目引入video.js播放不同格式视频

    很多小伙伴使用原生video标签播放服务器返回的地址的视频,但是会发现video标签对视频的格式限制很多,限制MP4,WebM,Ogg三种格式的视频格式。但是对于需求不限制于此,就需要引入插件库,这里引入第三方插件库video.js来实现更多的需求。注意:video.js也限制视频格式,可在

    2024年02月11日
    浏览(33)
  • Vue 项目中引入本地第三方 JS 库

    ESLint 语法检测会报错: \\\'$\\\' is not define   ESLint 语法检测不会报错   ESLint 语法检测不会报错   ESLint 语法检测会报错: \\\'$\\\' is not define 项目开启了 ESLint 语法检测的话,会报一个 error : \\\'$\\\' is not defined。 1、在每一个使用 $ 的代码行上 加  /* eslint-disable */  ,忽略该报错。 2、在根

    2024年02月04日
    浏览(44)
  • vue3项目引入本地js文件,实现一个音频播放按钮

    目前有一个需求就是在网页上放置一个音乐控制按钮,并且是在vue3项目里面。于是小白的我遇到了2个问题,第一个问题是如何实现没有进度条的播放按钮,这个网上有现成的代码,可以通过js代码切换不同的图片或者是别的样式,并不算难;第二个问题是如何在vue3项目中引

    2024年02月19日
    浏览(29)
  • Vue3+Vite+Pinia+Naive项目搭建之二:scss 的安装和使用

    前言 如果对 vue3 的语法不熟悉的,可以移步 Vue3.0 基础入门,快速入门。 github 开源库:Vue3-Vite-Pinia-Naive-Js gitee   开源库:Vue3-Vite-Pinia-Naive-Js 1. 安装依赖  2. 新增 src/assets/style/reset.scss 页面样式初始化 3. 新增 src/assets/style/common.scss 共用样式 4. 新增 src/assets/style/utils.scss 工

    2024年02月12日
    浏览(43)
  • vue、uniapp如何在js中获取scss的变量

    举例:在uniapp中会有一个uni.scss文件,我这边声明了一个$my-nav-bgColor的变量 uni.scss已经预处理过了,我们不需要引入可以直接使用 需要在uni.scss中导出 在你要用的页面引入 就可以正常使用了 自己定义的scss文件同样,只是多了一步引入

    2024年02月10日
    浏览(22)
  • uni-app(Vue3/Vite) + vant UI(Vue3版本)+ js 按需引入的项目搭建

            因为要完成软件工程的项目,要做一个nativeApp,看了很多的技术文档以后决定使用多端兼容的uni-app来开发。组件方面的话最后决定使用目前比较火的Vant UI。但是看了CSDN和掘金上面的很多文章,似乎没有一篇是关于uni-app中使用Vite对vant组件进行按需引入(可能这个

    2023年04月09日
    浏览(34)
  • SCSS全局配置 vue项目(二)

    目录 1、先要查看node版本         2、安装对应的node-sass、sass-loader版本 2.1根据项目使用的node版本安装对应的node-sass版本 2.2根据node-sass版本选择兼容的sass-loader版本,不然项目无法正常运行 3、在 vue.config.js 中配置:  4、在组件中的具体使用 1、先要查看node版本      

    2024年04月27日
    浏览(23)
  • vue项目中使用CDN引入

    CDN(内容分发网络)指请求资源的方式,即通过script头去请求对应的脚本资源的一种方式,项目里配置之后不需要通过npm包管理工具去下载配置的包。 目的:将引用的外部js、css文件剥离开来,不编译到vendor.js中,而是用资源的形式引用,这样浏览器可以使用多个线程异步将

    2024年02月11日
    浏览(40)
  • vue项目中,动态src引入图片,并且js根据文件名后缀,判断文件图片、视频、文档、pdf等类型的方法

    vue根据文件地址,获取后缀,根据后缀判断类型,然后根据类型动态展示不同类型的照片 1、处理后缀,根据后缀判断类型   2、根据返回的结果,直接将文件名命名为返回的结果,比如我有个图片类型的文件,经过上述的方法,返回的是image,那我直接要显示的图片名称就为

    2024年02月06日
    浏览(30)
  • Vue项目 css下载字体并引入使用

    1.下载字体         下载字体: 字体下载,字体大全,免费字体下载,在线字体|字客网 字客网是全球知名的字体下载与分享网站,齐全的中文,日文,韩文,英文,图标,美术设计,毛笔,钢笔,手写,书法字体大全,提供找字体,字体识别,字体下载,在线字体预览,字体转换,字体设计等服务

    2024年01月16日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包