原标题:缩减 SCSS 50%样式代码的 14 条实战经验

作者:feishi123

前言

Sass是CSS3语言的扩展,它能帮你更省事地写出更好的样式表,使你摆脱重复劳动,使工作更有创造性。因为你能更快地拥抱变化,你也将敢于在设计上创新。你写出的样式表能够自如地应对修改颜色或修改HTML标签,并编译出标准的CSS代码用于各种生产环境。Sass语法比较简单,难点在于如何将Sass运用到实际项目中,解决CSS存在的痛点,从而提高我们效率。经过实际项目的摸索,总结了以下14条实践经验进行分享,希望能帮助大家扩宽思维,更好地将Sass运用到实际项目中。在项目中,我们使用支持传统的类CSS语法—— Scss ,所以以下项目经验总结分享以 Scss为例。

1、变量 $ 使用

我们可以通过变量来复用属性值,比如颜色、边框大小、图片路径等,这样可以做到更改一处,从而进行全局更改,从而实现“换肤”的功能。

实例1:我们的组件库,利用变量配置,进行统一更改组件的颜色、字体大小等(换肤):

$color-primary: #3ecacb;

$color-success: #4fc48d;

$color-warning: #f3d93f;

$color-danger: #f6588e;

$color-info: #27c6fa;

实例2:图片的配置及全局引入

Scss中图片的使用,可能存在以下2个问题:

(1)如果样式文件和使用该样式文件的vue文件不在同一目录会出现图片找不到

(2)如果将图片路径配置变量写在vue文件的style中,但是该写法导致图片和样式分离

我们可以采用将图片路径写成配置文件,然后进行全局引入,这样可以统一更改图片路径(并且该方法只会在使用相应图片时进行加载,不会导致额外性能问题):

$common-path: './primary/assets/img/';

$icon-see: $common-path+ '';

$icon-play: $common-path+ '';

$icon-comment: $common-path+ '';

$icon-checkbox: $common-path+ '';

2、@import 导入Scss文件

(1)Css中的@import规则,它允许在一个css文件中导入其他css文件。然而,后果是只有执行到@import时,浏览器才会去下载其他css文件,这导致页面加载起来特别慢。

(2)Scss中的@import规则,不同的是,scss的@import规则在生成css文件时就把相关文件导入进来。这意味着所有相关的样式被归纳到了同一个css文件中,而无需发起额外的下载请求。

实例1:组件库中统一将组件的样式文件import 进 中 ,然后如果项目中有使用组件库的地方只需要在项目的入口处,引入 文件,如下所示在文件中引入各组件的样式文件:

@import "./";

@import "./";

@import "./";

3、局部文件命名的使用

scss局部文件的文件名以下划线开头。这样,scss就不会在编译时单独编译这个文件输出css,而只把这个文件用作导入。在使用scss时,混合器mixins是最适合的使用场景,因为混合器不需要单独编译输出css文件。

实例1:将混合器的名称写成局部文件命名的方式,如下图所示

img

4、Scss的嵌套功能和父选择器标识符

我们可以使用嵌套功能和父选择器标识符 & 来缩减重复的代码,特别如果你CSS类采用BEM命名规范,样式类命名存在冗长的问题。使用此功能,能解决BEM命名冗长的问题,且样式可读性更高。

实例1:嵌套功能和父选择器标识符 & 解决BEM冗长问题:

.tea-assignhw {

&__top {

margin: 0;

}

&__content {

padding-left: 45px;

}

&__gradeselect {

width: 158px;

}

}

**实例2:**嵌套中使用子选择器、兄弟选择器和伪类选择器

(1)子选择器

&__hint {

margin: 20px;

font-size: 14px;

> p:first-child {

font-weight: bold;

}

}

(2)兄弟选择器

&__input {

width: 220px;

& + span {

margin-left: 10px;

}

}

(3)伪类选择器

&__browse {

background: url( $btn-search) no-repeat;

&:hover {

background: url( $btn-search) -80px 0 no-repeat;

}

&:visited {

background: url( $btn-search) -160px 0 no-repeat;

}

}

5、@mixin 混合器和 @extend 指令的使用

变量使你能够复用属性值,但如果想要复用一大段规则呢?传统的做法是,如果在样式表

中发现重复,就会把公共的规则抽离出来放到新的CSS类中。

在Scss中可以使用混合器@mixin和@extend继承指令来解决以上提到的复用一大段规则的场景。但两者的使用场景又有啥区别呢?

(1)@mixin主要的优势就是它能够接受参数。如果想传递参数,你会很自然地选择@mixin而不是@extend,因为@extend不能够接受参数

(2)因为混合器规则都混入到其他类中,所以在输出的样式表中不能完全避免重复。选择器继承的意思就是让一个选择器能够复用另一个选择器的所有样式,但又不重复输出这些样式属性;即使用@extend产生 DRY CSS风格的代码(Don't repeat yourself)

综上所述,如果你需要传参数,只能使用@mixin混合器,否则用@extend继承来实现更优。

实例1:@mixin混合器的使用

@mixin paneactive( $image, $level, $vertical) {

background: url( $image) no-repeat $level$vertical;

height: 100px;

width: 30px;

position: relative;

top: 50%;

}

&--left-active {

@include paneactive( $btn-flip, 0, 0);

}

&--right-active {

@include paneactive( $btn-flip, 0, -105px);

}

实例2:@extend继承的使用

.common-mod {

height: 250px;

width: 50%;

background-color: #fff;

text-align: center;

}

&-mod {

@extend .common-mod;

float: right;

}

&-mod2 {

@extend .common-mod;

}

6、@mixin 混合器默认参数值的使用

在@include混合器时不必传入所有的参数,我们可以给参数指定一个默认值,如果所需要传的参数是 默认值,则@include时可以省略该参数;如果所需要传的参数不是默认值,则@include时则传入新的参数。

实例1:@mixin混合器默认参数值的使用

@mixin pane( $dir: left) {

width: 35px;

display: block;

float: $dir;

background-color: #f1f1f1;

}

&__paneleft {

@include pane;

}

&__paneright {

@include pane(right);

}

7、#{} 插值的使用

通过 #{} 插值语句可以在选择器或属性名中使用变量。当有两个页面的样式类似时,我们会将类似的样式抽取成页面混合器,但两个不同的页面样式的命名名称根据BEM命名规范不能一样,这时我们可使用插值进行动态命名。

实例1:页面级混合器中的类名利用#{}插值进行动态设置

@mixin home-content( $class) {

. #{$class} {

position: relative;

background-color: #fff;

overflow-x: hidden;

overflow-y: hidden;

&--left {

margin-left: 160px;

}

&--noleft {

margin-left: 0;

}

}

}

8、运算的使用

Sass支持数字的加减乘除、取整等运算 (+, -, *, /, %)

实例1:input组件根据输入框的高度设置左右内边距,如下所示:

.ps-input {

display: block;

&__inner {

-webkit-appearance: none;

padding-left: #{$--input-height + 10

};

padding-right: #{$--input-height + 10

};

}

}

9、相关scss自带函数的应用

scss自带一些函数,例如hsl、mix函数等。

**实例1:button组件的点击后颜色是将几种颜色根据一定的比例混合在一起,生成另一种颜色。**如下所示:

&:focus {

color: mix($--color-white, $--color-primary, $--button-hover-tint-percent);

border-color: transparent;

background-color: transparent;}

&:active {

color: mix($--color-black, $--color-primary, $--button-active-shade-percent);

border-color: transparent; background-color: transparent;

}

10、相关scss自带函数的应用

@for指令可以在限制的范围内重复输出样式,每次按变量的值对输出结果进行变动。

实例1:例如项目中需要设置hwicon类底下第2到8个div子节点需设置样式,如下所示:

@ for$ifrom 2 through 8 {

.com-hwicon {

> div:nth-child( #{$i}) {

position: relative;

float: right;

}

}

}

11、each遍历、map数据类型、@mixin/@include混合器、#{}插值 结合使用

可通过结合each遍历、map数据类型、@mixin/@include混合器、#{}插值,从而生成不同的选择器类,并且每个选择器类中的背景图片不同,如下所示:

$img-list: (

(accessimg, $papers-access),

(folderimg, $papers-folder),

(bmpimg, $papers-bmp),

(xlsimg, $papers-excel),

(xlsximg, $papers-excel),

(gifimg, $papers-gif),

(jpgimg, $papers-jpg),

(unknownimg, $papers-unknown)

);

@each $label, $valuein$img-list {

.com-hwicon__ #{$label} {

@include commonImg( $value);

}

}

12、样式代码检查校验 —— stylelint 插件

CSS不能算是严格意义的编程语言,但是在前端体系中却不能小觑。CSS是以描述为主的样式表,如果描述得混乱、没有规则,对于其他开发者一定是一个定时炸弹,特别是有强迫症的人群。CSS看似简单,想要写出漂亮的 CSS还是相当困难。所以校验 CSS规则的行动迫在眉睫。stylelint是一个强大的现代 CSS检测器,可以让开发者在样式表中遵循一致的约定和避免错误。

**(1)需要安装gulp、stylelint、gulp-postscss 、 postcss-reporter、stylelint-config-standard,**安装命令为:

npm install gulp stylelint gulp-postscss postcss-reporter

stylelint-config-standard--save-dev

(2)安装完成后会在项目根目录下创建文件,文件配置为:

var reporter = require( 'postcss-reporter');

var stylelint = require( 'stylelint');

var stylelintConfig = {

'extends': 'stylelint-config-standard',

'rules': {

'at-rule-no-unknown': [

true, {

'ignoreAtRules': [

'extend',

'include',

'mixin',

'for'

]

}

]

}

};

( 'scss-lint', function{

var processors = [

stylelint(stylelintConfig),

reporter({

clearMessages: true,

throwError: true

})

];

returngulp.src(

[ 'src/style/*.scss']// 需要工具检查的scss文件

).pipe(postcss(processors));});

( 'default', [ 'scss-lint']);

(3) stylelint-config-standard 检验规则

stylelint-config-standard为stylelint官方推荐的标准校验规则,具体校验规则有哪些内容,可参照官网。

(4)运行命令进行样式检查

13、样式自动修复插件 —— stylefmt 插件

stylefmt是一个基于 stylelint的代码修正工具,它可以基于stylelint的代码规范约定配置,对可修正的地方作格式化输出。

(1)配置文件如下:

var stylefmt = require( 'gulp-stylefmt'); // css格式自动调整工具

( 'stylefmt', function{

returngulp.src(

[ 'src/style/student/'// 需要工具检查的scss文件

]).pipe(stylefmt(stylelintConfig))

.pipe(( 'src/style/dest/student'));});

( 'fix', [ 'stylefmt']);

(2)运行命令进行样式修复,如下图所示

img

14、将scss语法编译成css语法——gulp-sass 插件

初写scss代码时,由于对语法不熟悉等,写出来的scss代码所得到的页面效果,并不是我们想要的。这时,我们可以使用gulp-sass插件来监听scss代码,实时生成css代码,从而可以通过查看css代码,来判断所写的scss代码是否正确。

(1)配置文件如下:

var gulpsass = require( 'gulp-sass');

( 'gulpsass', function{

returngulp.src( 'src/style/components/')

.pipe(( 'error', ))

.pipe(( 'src/style/dest'));});

( 'watch', function{

( 'src/style/components/', [ 'gulpsass']);

});复制代码复制代码

(2)运行命令从而监听scss文件,动态编译scss代码生成css代码文件,如下图所示

img

以上就是总结的14条 SCSS 实战经验总结的分享。 返回搜狐,查看更多

责任编辑:

button 样式_缩减 SCSS 50%样式代码的 14 条实战经验相关推荐

  1. bootstrap起步 全局css样式概览 全局css样式_栅格 全局css样式_排版

    http://www.bootcss.com/基本模板 https://v3.bootcss.com/getting-started/#template bootstrap起步 <!DOCTYP ...

  2. uniapp动态修改样式_掌握Photoshop图层样式技术

    凹凸贴图效果 "等等,什么?" 您会惊叹:""图层样式"菜单中没有凹凸贴图效果!" 的确如此,但是通过将"图案覆盖"和& ...

  3. 行内块样式_现代块引用样式

    行内块样式 View demo 查看演示Download Source 下载源 Today we are going to create some fancy block quote styles. ...

  4. mac 设置终端样式_如何将终端样式设置为freeCodeCamp或任何您想要的样式

    mac 设置终端样式 "It's over 9,000!" That iconic line from the show Dragon Ball Z inspired the na ...

  5. 5 好看的字体样式_嫌电脑字体样式太少,这款小软件几百种的样式随便你选择...

    在日常工作中,发现电脑字体默认样式非常少,而且还不美观,文档啊.PPT啊一打开全是一样的宋体啊黑体啊等等,如果你工作的单位有要求字体样式,那就算了,如果不是或者你是个设计,那这款软件真的好用,几百种字 ...

  6. button按钮样式_一篇文章带你了解CSS3按钮知识

    在实际开发中,按钮的应用是必不可少.使用 CSS 来制作按钮,可以更有新意,更有趣,也可以自定义自己想要的样式. 一.平面样式CSS按钮 平面样式按钮的使用现在非常流行,并且符合无处不在的平面设计趋势 ...

  7. button 样式_实战PyQt5: 111-可以使用QSS样式表的部件

    可以使用QSS样式表的部件 QSS样式表支持各种部件,属性,伪状态和子控件,从而可以实现定制部件的外观,下面我们将详细列出可以使用QSS样式表的部件: QAbstractScrollArea:所有派生 ...

  8. 前端基础之《Bootstrap(3)—全局CSS样式_排版、代码、表格和按钮》

    一.排版 1.标题(.page-header) 从<h1>到<h6>均可使用page-header样式. <body><div><h1 class ...

  9. wxss 点击样式_小程序05-样式WXSS(示例代码)

    WXSS (WeiXin Style Sheets)是一套样式语言,用于描述 WXML 的组件样式. 与 CSS 相比,WXSS 扩展的特性有: 尺寸单位 rpx(响应式长度单位),可以根据屏幕宽度进 ...

最新文章

  1. 安卓怎么用抖音做锁屏_香港超级推荐全网霸屏快速上排怎么做
  2. Program type already present: android.support.v4.app.BackStackRecord$Op
  3. python stm32-python学习(一)
  4. css入门教程资料(5)
  5. cocos creator 方法数组_基于 Cocos 游戏引擎的音视频研发探索
  6. 容器编排技术 -- 创建Kubernetes集群
  7. 这就是数据分析之数据可视化基础概念及工具
  8. 解决左下角没有显示桌面图标
  9. 删除选修c语言课程的女生成绩记录,pta10-1 查询没有选修‘C语言‘课程的学生 (10分)...
  10. ext中的EXT.XTemplate()
  11. EIGRP DUAL算法
  12. ASP.NET基础教程-C#与JAVA的比较
  13. lj245a引脚功能图_CA3140中文资料-引脚图及功能
  14. CMD操作查看电脑IP
  15. 嵌入式入门必去的网站 —— 介绍的非常详细
  16. 数据删掉了怎么恢复?数据删除后还能恢复吗
  17. 2019京东全球科技探索者大会议程抢先曝光!
  18. NLP学习路径(三):NLP中文分词技术
  19. Cobalt Strike Malleable C2
  20. 前端页面field_前端组件

热门文章

  1. MyBatis 数据持久层
  2. C# 数据库连接池 线程安全 单例模式 的实现
  3. mysql聚簇索引 和主键的区别_[MySQL] innoDB引擎的主键与聚簇索引
  4. db2数据库日期减一天_DB2 数据库中的日期与时间如何正确操作?(2)
  5. 人脸识别门禁_小区人脸识别门禁或取代传统门禁刷卡方式
  6. ubuntu java 1.6 安装,ubuntu 中安装java jdk 1.6
  7. Java Integer类lowerOneBit()方法与示例
  8. 16位的数字高字节和低字节_掩盖8位数字的较低和较高半字节| 8085微处理器
  9. iis php mysql 集成_如何在IIS上集成php(iis+mysql+php+zend)
  10. ntce服务器不稳定,当心!你的教师资格证成绩失效了!| 服务