CSS处理器-Less/Scss
HTML系列:
CSS系列:
- CSS基础知识筑基
- 常用CSS样式属性
- CSS选择器大全48式
- CSS布局秘籍(1)-任督二脉BFC/IFC
- CSS布局秘籍(2)-6脉神剑
- CSS动画-transition/animation
- CSS处理器-Less/Scss
01、CSS处理器
1.1、什么是CSS预处器?
CSS预处器(CSS Preprocessor /ˌpriːˈprəʊsesə/)是基于CSS之上的一种“新”的CSS语言,在CSS基础上添加了一些编程特性。可以认为是CSS的扩展,或CSS的超集,让CSS的编写更简洁、功能更强大。
那为什么需要CSS预处理器呢?—— 主要是为了加强CSS,解决CSS的一些弊端:
- 可读性差:全是一堆属性集合,没有层级管理。
- 可维护性差:不支持复用、继承,导致很多重复代码。
- 不够灵活:缺少一些编程特性的支持,代码编写不够灵活、智能。
CSS预处器就是为了解决这些问题, 为了像其他编程语言一样,编写简洁、维护更容易、可读性强、适应性强。
CSS预处器特性:
- 选择器嵌套:支持选择器嵌套、属性嵌套,呈现层级关系,使得结构更清晰、更易维护。
- 变量、函数、运算等编程特性:支持更灵活、强大的变量、函数、运算、逻辑控制,如常用的字符、颜色、数字运算和函数。
- 代码复用:混用Mixin、继承等。
- CSS输出:预处理器的基本原理就是在开发编译阶段,把
预处理CSS代码
翻译成标准的CSS代码
,然后浏览器执行标准CSS代码。
1.2、CSS预处理框架
CSS预处器比较流行的实现语言:Sass/Scss、Less、Stylus
- Sass/Scss:Scss 是 Sass的升级版,Scss 是最成熟、最稳定、最强大的CSS预处理器,兼容所有CSS版本,使用广泛。
- Less:Less (/les/ )简洁、学习容易,功能也比较完整。
- stylus:富于表现力、动态的、健壮的 CSS。
比较 | Less | Sass/Scss |
---|---|---|
变量申明 |
@vname: #FFF color : @vname 变量插值: @{XXXX} |
$vname: #FFF color : $vname 变量插值: ${XXXX} |
嵌套规则 | 选择器嵌套:div p a{} = div{ p{ a{}}} |
选择器嵌套:同Less |
代码复用 | 混入(Mixin):复用(拷贝)代码.class{ } { .class() } @extend 继承 aclass :extend(pclass) |
混入(Mixin):复用(拷贝)代码@minxin class{ } { **@include** class} @extend 继承:原理是用了并集处理器放公共样式 |
条件语句 | 不支持,用if() 函数模拟 |
支持:if{ } else ,for{}循环 |
运行环境 | JS编写的,可以运行在Node、浏览器环境 | 有Ruby版本、新的dart版本,需要安装对应环境 |
1.3、后处理器
后处理器(post-processor),就是写完CSS后,对CSS进行再加工处理,如cssNext、autoprefixer,用来对CSS代码进行兼容性完善、代码压缩等处理。
02、Less
中文文档:https://less.bootcss.com/
在线转换工具:http://www.wetools.com/less-to-css
2.1、安装与使用
在开发阶段,直接引用less
,需引入less的JS文件。
<link rel="stylesheet/less" type="text/css" href="styles.less" />
/* less的JS文件 */
<script src="https://cdn.jsdelivr.net/npm/less@4" ></script>
正式环境肯定是要提前编译输出CSS文件,这就需要安装less
包来编译less
代码。需要NodeJS环境,然后通过npm指令安装:npm install -g less
2.2、基本语法
嵌套:选择器嵌套/&父级
这个功能确实很好用,代码结构都清晰了,多用于后代选择器,其他各种(关系)选择器都可以用。
申明:跟HTML结构一样,嵌套使用。
父选择器&:用&
符号标识父级,伪元素、属性
嵌套必须用&
开头。
.less
示例 & 编译结果示例代码:
/* <p> <span>子曰:</span> <span primary>道听而涂说,德之弃也。</span> </p> */
@pcolor: gold;
#quote(@content, @vertical, @padding) {
content: @content;
vertical-align: @vertical;
padding: @padding;
}
p {
background-color: lighten(@pcolor, 30%);
border:@pcolor solid 10px;
border-image:repeating-linear-gradient(-45deg,darken(@pcolor, 5%) 5px,lighten(@pcolor, 5%) 10px) 10;
text-align: center;
line-height: 3em;
span {
color: darken(@pcolor, 20%);
font-size: 1.5em;
font-weight: 500;
font-family: '汇文明朝体';
&[primary] {
padding: 0 5px;
&::before {
#quote("⌈", 4px, 0 6px 0 0);
}
&::after {
#quote("⌋", -4px, 0 0 0 6px);
}
}
}
}
» 编译结果
/* <p> <span>子曰:</span> <span primary>道听而涂说,德之弃也。</span> </p> */
p {
background-color: #ffef99;
border: gold solid 10px;
border-image: repeating-linear-gradient(-45deg, #e6c200 5px, #ffdb1a 10px) 10;
text-align: center;
line-height: 3em;
}
p span {
color: #998100;
font-size: 1.5em;
font-weight: 500;
font-family: '汇文明朝体';
}
p span[primary] {
padding: 0 5px;
}
p span[primary]::before {
content: "⌈";
vertical-align: 4px;
padding: 0 6px 0 0;
}
p span[primary]::after {
content: "⌋";
vertical-align: -4px;
padding: 0 0 0 6px;
}
注释
同JS,支持单行、多行。
- 单行注释:
//
编译后会丢掉,大概是因为CSS中不支持。 - 多行注释:
/**/
编译后会保留
@import导入
- 导入css
- 导入less,可省略扩展名,编译时会输出代码。
@import "../css/default.css";
@import "t2"; /* t2.less */
运算符+、-、*、/
支持任何单位的数值、颜色、变量的运算,结果采用最左边的单位。
- +、-,会自动做部分单位换算,转换失败就忽略单位。
- 乘法和除法不作转换。
2.3、@变量:运算/插值/~转义
@
开头申明变量,支持表达式。可以定义在外面,也可以定义在规则集内部,这会影响他们的作用域。
作用域:同JS,有提升的效果(同一作用域内,可以先使用后申明),作用域向上查找(继承)。
变量插值:用在类名上,替换为变量值,也是一种变量使用方式,需带花括号:@{vname}
~转义:包含特殊字符,需要引号包起来的变量值,申明格式:@var : ~'value';
@var : ~"value";
@margin-vertical: 0.5em;
@line-height: 1.5em + @margin-vertical; /**最好单位一致,px+em会转换失败 **/
@li-name: li;
@media768: ~'(min-width: 768px)'; /** 需要引起来的字符 **/
@border: 1px solide #000;
@media @media768 {
@{li-name} { /** 变量插值,也是一种使用方式,括起来 **/
background-color: aliceblue;
margin: @margin-vertical 0; /** 使用变量 **/
line-height: @line-height;
border: @border;
}
}
» 编译结果:计算并替换最终值
@media (min-width: 768px) {
li {
background-color: aliceblue;
margin: 0.5em 0;
line-height: 2em;
border: 1px solide #000;
}
}
2.4、代码复用:Mixins/extend
混合(Mixins)就是复用代码,复用一组CSS规则、一条规则值,类似JavaScript的函数调用。复用(复制)代码,直接把一个类里面的代码拷贝过来,命名空间的混入也一样,把类当函数调用。
申明:class(){}
类名一般为#
、.
开头,括号()
可带、可不带。带括号时,编译不会输出该申明代码,so,建议一般都带上括号。
使用:class()
,就像函数调用一样,把class{}
中的规则代码复制过来。
.border
{
border: 1px solid #66F;
border-left-width: 3px;
}
li {
padding: 0 5px;
.border(); /*复用(复制)代码*/
}
» 编译结果: 注意上面被复用的类.border
也会编译输出,如不需要申明时加上括号()
。
.border {
border: 1px solid #66F;
border-left-width: 3px;
}
li {
padding: 0 5px;
/*复用(复制)代码*/
border: 1px solid #66F;
border-left-width: 3px;
}
命名空间:混合嵌套
按照 命名空间来组织管理复用的(mixins)代码。
申明:就是多层混合的嵌套,类似JavaScript里面的Object对象,可以通过.
来链式调用。
使用:使用的时候也是按照嵌套路径调用。
#namespace() { /** 申明命名空间 **/
.button-orange { /** 申明了两个子类 **/
background-color: orange;
border: @border;
&:hover {background-color: lighten(orange,20%);}
}
.button-blue{
background-color:skyblue;
border: @border;
&:hover {background-color: lighten(skyblue,20%);}
}
}
div{
button{
#namespace.button-blue(); /** 使用混入,通过命名空间调用 **/
}
}
» 编译结果:
div button {
background-color: skyblue;
border: 1px solide #000;
/** 使用混入,通过命名空间调用 **/
}
div button:hover {
background-color: #def2fa;
}
映射Maps:混合[子属性]
像JavaScript中的Map一样使用,复用规则里面的属性值。
使用:用[]
的形式获取css属性值,#map[pname]
#border(){
border: 1px solid black;
color: red;
}
div {
#border();
border-color: #border[color];
}
» 编译结果:
div {
border: 1px solid black;
color: red;
border-color: red;
}
混合参数(@para)
混入支持带参数,在使用的时候传入参数,参数支持默认值,这个还挺好用的!
#namespace {
.button(@color:orange) { /* 带参数,并设置了默认值 */
background-color: @color;
border:1px solid @color;
&:hover {
background-color: lighten(@color, 20%);
}
}
}
div {
button {
#namespace.button(blue);
color: #namespace.button[background-color];
}
}
extend()继承
继承另外一个类的规则集,效果同混入,使用起来更优雅一点。
使用:class :extend(pclass)
2.5、函数
内置了很多函数,用于字符、颜色、算数技术。函数手册
属性 | 描述 |
---|---|
percentage(n) | 转换为百分比值, |
saturate(color, 5%) | 颜色饱和度增加5% |
lighten(color, 5%) | 颜色亮度降低5% |
darken(color, 5%) | 颜色亮度增加5% |
if(condition, tv,fv) | IF函数,同JS的三元运算符? |
replace(str, par, rep) | 字符替换 |
extract(list, index) | 提取集合的值 |
each(list, rules) | 循环输出规则 |
03、Sass/Scss
中文文档:https://www.sass.hk/docs/
Less、Scss使用区别并不大,很多用法都比较相似,比较常用的嵌套是一样的,变量、混入的语法稍有不同。相对而言,Less稍简洁,Scss更强大点,学习一个就行了,很多框架是都支持,实际需要的时候看看文档即可。
️版权申明:版权所有@安木夕,本文内容仅供学习,欢迎指正、交流,转载请注明出处!原文编辑地址-语雀
CSS处理器-Less/Scss的更多相关文章
- 前端编码规范(4)—— CSS 和 Sass (SCSS) 规范
CSS and Sass (SCSS) style rules ID and class naming ID和class(类)名总是使用可以反应元素目的和用途的名称,或其他通用名称.代替表象和晦涩难懂 ...
- CSS预处理器Sass(Scss)、Less、Stylus
CSS 预处理编译器能让我成程序化其的方式编写CSS代码,可以引入CSS中没有的变量.条件.函数等特性,从而让代码更简单易维护,但一般按预处理器语法编写的代码无法直接在浏览器中运行,需用通过工具比如g ...
- css篇-less,scss 用calc问题
在less或者scss中 calc(100% -4rem) 等带单位混合运算会被less解析忽略单位,全部按照百分比计算,此例中的计算被less编译成calc(96%), 解决办法: width:(& ...
- Webpack干货系列 | 怎么运用 Webpack 5 处理css/scss/sass、less、stylus样式资源
程序员优雅哥简介:十年程序员,呆过央企外企私企,做过前端后端架构.分享vue.Java等前后端技术和架构. 本文摘要:主要讲解webpack 5 如何高效处理CSS 资源.scss/sass 资源.l ...
- SCSS(SASS、CSS)学习
看的这篇文章 http://www.frostsky.com/2014/07/sass-scss/ 写的还比较清晰 SASS是CSS3的一个扩展,增加了规则嵌套.变量.混合.选择器继承等等.通过使用命 ...
- Sass带来的变革_sass, scss 教程_w3cplus - Google Chrome
Sass带来的变革 作者:大漠 日期:2014-11-17 点击:5291 sass scss 接触Sass差不多有一个年头了,在这一年来的时间中,也花了不少心思在Sass的学习上.同时也让自己喜欢上 ...
- [翻译]理解CSS模块方法
在这个前端发展日新月异的世界,能够找到有所影响的概念相当困难,而将其准确无误的传达,让人们愿意尝试,更是难上加难. 拿CSS来看,在我们写CSS时,工具侧最大的变化,也就是CSS处理器的使用,如:可能 ...
- CSS Modules入门及React中实践(内附webpack4配置)
本篇文章以整理为主,自己进行了部分修改,如有侵权,请告知 CSS Modules介绍 CSS Modules是什么东西呢?首先,让我们从官方文档入手:GitHub – css-modules/css- ...
- SCSS详解
SCSS入门 CSS预处理器 定义了一种新的专门的编程语言,编译后成正常的CSS文件.为CSS增加一些编程的特性,无需考虑浏览器的兼容问题,让CSS更加简洁,适应性更强,可读性更佳,更易于代码的维护等 ...
随机推荐
- 面试突击79:Bean 作用域是啥?它有几种类型?
Spring 框架作为一个管理 Bean 的 IoC 容器,那么 Bean 自然是 Spring 中的重要资源了,那 Bean 的作用域是什么意思?又有几种类型呢?接下来我们一起来看. PS:Java ...
- KingbaseES ALTER TABLE 中 USING 子句的用法
using子句用于在修改表字段类型的时候,进行显示的转换类型. 1.建表 create table t(id integer); 2.插入数据 insert into t select generat ...
- 【Spring】Spring bean中id和name的差异
id和name都是spring 容器中中bean 的唯一标识符. id: 一个bean的唯一标识 , 命名格式必须符合XML ID属性的命名规范 name: 可以用特殊字符,并且一个bean可以用多个 ...
- 第六章:Django 综合篇 - 10:消息框架 message
在网页应用中,我们经常需要在处理完表单或其它类型的用户输入后,显示一个通知信息给用户. 对于这个需求,Django提供了基于Cookie或者会话的消息框架messages,无论是匿名用户还是认证的用户 ...
- 8.云原生之Docker容器镜像构建最佳实践浅析
转载自:https://www.bilibili.com/read/cv15220861/?from=readlist 本章目录 0x02 Docker 镜像构建最佳实践浅析 1.Dockerfile ...
- KVM里安装不是原装的winxp系统镜像
从网上下载的winxp系统镜像,虽然是iso格式的,但是里面的内容是如下情况的 因此安装的话,需要采取如下步骤 1.添加一个光驱引导,挂载一个iso格式的pe 2.再添加一个光驱,挂载iso格式的wi ...
- Kubernetes(k8s)通过环境变量将 Pod 信息呈现给容器
Downward API 有两种方式可以将 Pod 和 Container 字段呈现给运行中的容器: 环境变量 卷文件 这两种呈现 Pod 和 Container 字段的方式统称为 Downward ...
- Nginx缓存了DNS解析造成后端不通--代理
文章转载自:https://segmentfault.com/a/1190000022365954 1 问题现象 我们使用 Nginx 的时候,经常会用到 Proxy 功能,为了方便管理,后端站点或者 ...
- 企业信息化建PLM系统、ERP系统、MES系统是单个逐步建设好,还是同时上比较好?
企业信息化建PLM系统.ERP系统.MES系统肯定是单个逐步建设好啊,不仅仅是各个系统单独建设,系统内各模块的实施也应该先后逐步推进,切不可想着一口吃个大胖子,一股脑的全上,求全求快是很多系统实施失败 ...
- Java(15)Object类
前言 Object类是Java中所有类的始祖,在Java中每个类都扩展了Object.如果没有明确地指出超类,Object就被认为是这个类的超类.由于在Java中每个类都是由Object类扩展而来的, ...