20190421-那些年使用过的CSS预处理器(CSS Preprocessor)
写在前面的乱七八糟的前言:
emmm,不得不说,早上七点是个好时间,公园里跳广场舞的大妈,街边卖菜刀看报的大爷,又不得不说,广州图书馆是个好地方,该有的安静,该有的人气,听着楼下小孩子的声音,看着周围各色各样的人,emmm比如:无视请勿饮食的标识语正在吃东西的小姐姐,好像是个三明治- -,我不会承认,我也饿了的TAT,老生常谈那么几句,一直秉承着不仅要学会用也要知道用的这些从何处而来,所构成的逻辑及背后的故事,总不能哪天面试官问你,谈谈你对CSS预处理器的看法,或问,你觉得Sass方便在哪,然后一脸懵逼的双目对视?真是像极了爱情?emmmm,好的,我皮够了,下面依旧是从"是什么/有什么/为什么"切入。
目录
1、她从何处来——CSS预处理器的产生
2、她长什么样——什么是CSS预处理器
3、她家几姐妹——CSS预处理器分类(Sass、Less、Stylus)
4、如何攻略她——CSS预处理器优缺点
5、如何使用她——CSS预处理器的使用
5.1变量
5.2运算
5.3嵌套
5.4注释
5.5代码的重用:混合、扩展、函数、插入文件
5.6高级用法:条件语句、循环语句、自定义函数
内容
1、她从何处来——CSS预处理器的产生
既然叫CSS预处理器,肯定跟CSS有某些不可描述的故事,CSS是一门非程序式的语言,变量×,函数×,SCOPE(作用域)×,条件语句×,在前期进行界面设计时,需要书写大量的、无逻辑、不易维护、不易扩展、不易重复调用的代码,诚然,经验老道的大佬们都会采用公共类名、各类选择器等,但对于老夫这种小白emmm,CSS预处理器就是福音呐——
2、她长什么样——什么是CSS预处理器
CSS预处理器的基本思想是:用一种专门的编程语言,为CSS加入一些编程特性,将CSS作为目标生成文件,然后开发者只需要使用这种语言进行编码。在无需考虑浏览器兼容性问题的前提下,使用变量/简单的逻辑程序/函数等在编程语言中的一些基本特性。
3、她家几姐妹——CSS预处理器分类
目前使用最多的三款CSS预处理器:Sass、Less、Stylus,讲真,最后一款,可能因为我还太小白,孤陋寡闻,以致听都没听过,没使用过没有发言权,就不种草了。
3.1Sass
Sass产生:2007年,目前为止,最早最成熟的CSS预处理器,拥有ruby社区与compass框架的支持,受Less影响,已进化到了全面兼容CSS的SCSS
3.2Less
Less产生:2009年,受Sass影响较大,但又使用CSS语法,简单易上手,在ruby社区外支持者远超过Sass,但与Sass相比,编程功能不够,优点仅简单与兼容CSS,但神奇的是:Twitter Bookstrap采用Less做底层语言的。
3.3Stylus
Stylus产生:2010年,来自Node.js社区,主要用于给Node项目进行CSS预处理支持。
4、如何攻略她——CSS预处理器优缺点
4.1优点
↑开发速度
↑代码优化效率
代码更通俗易懂》》维护简单便捷
通俗一句旁白:Sass与Less就是CSS里的jQuery
4.2缺点
↓用户体验
↓网页打开速度
需要一定的学习过程
5、如何使用她——CSS预处理器的使用
5.1变量(Variables)
无需重复书写:将反复使用的css属性定义为变量,然后通过变量名来引用它们
赋予易懂的变量名:让人一眼看出属性值用途
5.2运算(Operations)
5.2.1数字运算(Number Operations)
支持数字的加减乘除,取整等(+;-;×;/;%),若必要时会在不同单位间转换值
关系运算(<;>;<=;>=;==;!=)
ps:除法运算与分割符(/)
/ 在 CSS 中通常起到分隔数字的用途,SassScript 作为 CSS 语言的拓展当然也支持这个功能,同时也赋予了 / 除法运算的功能
以下三种情况 / 将被视为除法运算符号:
- 如果值,或值的一部分,是变量或者函数的返回值
- 如果值被圆括号包裹
- 如果值是算数表达式的一部分
p {
font: 10px/8px; // Plain CSS, no division
$width: 1000px;
width: $width/2; // Uses a variable, does division
width: round(1.5)/2; // Uses a function, does division
height: (500px/2); // Uses parentheses, does division
margin-left: 5px + 8px/2px; // Uses +, does division
}
编译为
p {
font: 10px/8px;
width: 500px;
height: 250px;
margin-left: 9px;
}
如果需要使用变量,同时又要确保 / 不做除法运算而是完整地编译到 CSS 文件中,只需要用#{}插值语句将变量包裹
p {
$font-size: 12px;
$line-height: 30px;
font: #{$font-size}/#{$line-height};
}
编译为
p {font: 12px/30px; }
5.2.2颜色运算(Color Operations)
颜色值的运算是分段计算进行的,也就是分别计算红色,绿色,以及蓝色的值
p {
color: #010203 + #040506;
}
//01 + 04 = 05 02 + 05 = 07 03 + 06 = 09
编译为
p {color: #050709; }
但使用color functions比计算颜色值更方便一些
p {color: #010203 * 2;}
//01 * 2 = 02 02 * 2 = 04 03 * 2 = 06
编译为:
p {color: #020406; }
ps:若颜色值包含 alpha channel(rgba 或 hsla 两种颜色值),必须拥有相等的 alpha 值才能进行运算,因为算术运算不会作用于 alpha 值
颜色值的 alpha channel 可以通过opacify或 transparentize两个函数进行调整
$translucent-red: rgba(255, 0, 0, 0.5);
p {
color: opacify($translucent-red, 0.3);
background-color: transparentize($translucent-red, 0.25);
}
编译为
p {
color: rgba(255, 0, 0, 0.8);
background-color: rgba(255, 0, 0, 0.25);
}
IE 滤镜要求所有的颜色值包含 alpha 层,而且格式必须固定 #AABBCCDD,使用 ie_hex_str 函数可以很容易地将颜色转化为 IE 滤镜要求的格式
$translucent-red: rgba(255, 0, 0, 0.5);
$green: #00ff00;
div {
filter: progid:DXImageTransform.Microsoft.gradient(enabled='false', startColorstr='#{ie-hex-str($green)}', endColorstr='#{ie-hex-str($translucent-red)}');
}
编译为:
div {
filter: progid:DXImageTransform.Microsoft.gradient(enabled='false', startColorstr=#FF00FF00, endColorstr=#80FF0000);
}
5.2.3字符串运算(String Operations)
5.2.4布尔值运算(Boolean Operations)
5.2.5数组运算(List Operations)
使用list functions控制
5.3嵌套(Nested)
5.3.1选择器嵌套
保留Html中的代码结构,默认后代选择器
需子代选择器,则在子代前加>
&表示上一层
5.3.2属性嵌套(Nested Properties)
5.3.3伪类嵌套
5.4注释(Comment)
5.4.1多行注释/* */:完整输出到编译后文件
5.4.2单行注释/ /:在非compressed压缩模式下会被编译到CSS文件中
5.4.3强调注释/*! */:在/*后面加一个感叹号,表示这是"重要注释",即使是压缩模式编译,也会保留这行注释,通常可以用于声明版权信息
ps:插值语句 (interpolation) 也可写进多行注释中输出变量值:
$version: "1.2.3";
/* This CSS is generated by My Snazzy Framework version #{$version}. */
编译为
/* This CSS is generated by My Snazzy Framework version 1.2.3. */
5.5代码的重用:混合、扩展、函数、插入文件
5.5.1混合(Mixins)
将部分样式抽出,作为单独定义的模板,被多选择器调用,如某段样式经常用到多个元素时,需重复写多次,则可使用
5.5.1.1无参混合:声明:.name{ };调用:调用选择器
5.5.1.2带参混合:
5.5.1.2.1无默认值声明:.name(@param){ } 调用:name(parValue); parValue不可省
5.5.1.2.2有默认值声明:.name(param:value( )){ } 调用:name(parValue); parValue可省
ps:无参混合会在CSS中编译同名的class选择器,带参的不会。
5.5.2扩展(Extand)
5.5.3函数(Function)
5.5.4导入文件(@import)
在CSS中,并不喜欢用@import来导入样式,因为这样的做法会增加http的请求。但是在CSS预处理器中的导入(@import)规则和CSS的有所不同,它只是在语义上导入不同的文件,但最终结果是生成一个CSS文件。如果你是通赤“@import ‘file.css’”导入“file.css”样式文件,那效果跟普通CSS导入样式文件一样。注意:导入文件中定义了变量、混合等信息也将会被引入到主样式文件中,因此需要避免他们的相互冲突
5.6高级用法:条件语句、循环语句、自定义函数
5.6.1条件语句:@if @else
5.6.2循环语句:@for @while
5.6.3自定义函数
参考文献:
详说css与预处理器(以及less、sass、stylus的区别)
我是无处安放的小结:
现在是16:17分,除去中间吃掉的一个半小时,有点困了,emmm,但是,但是,刚刚手贱的认识了Sass的toolkit——Compass,停不下来了,艾玛真香,我快哭了。请容我休息一会,再整理补充~
现在是18:04分,本文最重点的部分还是打算另开一篇,好好盘一番,emmm最重要还是在怎么使用它,但是Sass的用法确实比Less高级那么一丢丢。希望不要太难搞啊~
20190421-那些年使用过的CSS预处理器(CSS Preprocessor)的更多相关文章
- 前端CSS预处理器Sass
前面的话 "CSS预处理器"(css preprocessor)的基本思想是,用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件.SASS是一种CSS的开发工 ...
- 关于前端CSS预处理器Sass的小知识!
前面的话 "CSS预处理器"(css preprocessor)的基本思想是,用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件.SASS是一种CSS的开发工 ...
- CSS预处理器——Sass、LESS和Stylus实践
CSS(Cascading Style Sheet)被译为级联样式表,做为一名前端从业人员来说,这个专业名词并不陌生,在行业中通常称之为“风格样式表(Style Sheet)”,它主要是用来进行网页风 ...
- CSS预处理器 Less Sass,Scss 编译 Sourcemap调试
sass.less和stylus的安装使用和入门实践 SASS用法指南 Sass Basics CSS预处理器 css preprocessor 预处理器即preprocessor,预处 ...
- 初识css预处理器:Sass、LESS
这篇文章是初步介绍css预处理的,详细学习请移步官网~ 什么是css预处理器 CSS 预处理器是一种语言, 通俗易懂的话来说就是“用一种专门的编程语言,进行 Web 页面样式编写,再通过编译器转化为正 ...
- css预处理器sass使用教程(多图预警)
css预处理器赋予了css动态语言的特性,如变量.函数.运算.继承.嵌套等,有助于更好地组织管理样式文件,以及更高效地开发项目.css预处理器可以更方便的维护和管理css代码,让整个网页变得更加灵活可 ...
- CSS预处理器Sass、LESS 和 Stylus
CSS 预处理器技术已经非常的成熟,而且也涌现出了越来越多的 CSS 的预处理器框架.本文向你介绍使用最为普遍的三款 CSS 预处理器框架,分别是 Sass.Less CSS.Stylus. 首先我们 ...
- Myth – 支持变量和数学函数的 CSS 预处理器
Myth 是一个预处理器,有点类似于 CSS polyfill .Myth 让你写纯粹的 CSS,同时还让你可以使用类似 LESS 和 Sass 的工具.您仍然可以使用变量和数学函数,就像你在其它预处 ...
- CSS 预处理器(框架)初探:Sass、LESS 和 Stylus
现在最为普遍的三款 CSS 预处理器框架,分别是 Sass.Less CSS.Stylus. 拿less来说,可以在页面上直接使用less文件,但要引用less.js进行解析:同时也可以直接将less ...
随机推荐
- MySQL之父造访腾讯云 为腾讯云数据库开源点赞
近日,技术大牛 MariaDB 公司创始人兼CTO Michael Widenius(又名Monty).MariaDB 基金会主席 Kaj 来到中国,针对MariaDB与腾讯云的技术合作进行回访.去年 ...
- vs中开发web站点使IIS Express支持局域网连接
vs中开发web站点使IIS Express支持局域网连接 在开发webapi的时候,客户端设备都会使用局域网的地址访问webapi,有时候需要调试api.这个时候就需要使用一些技巧了,这里我记录了我 ...
- css块级元素和行内元素详细解析
块级元素和行内元素是布局中常见的两种基本元素,但是未必有很多人深入的研究它们的细微差别. 常见块级元素:div p form ul ol li 等: 常见的行内元素:span stronh em; ...
- Linux 桌面玩家指南:06. 优雅地使用命令行及 Bash 脚本编程语言中的美学与哲学
特别说明:要在我的随笔后写评论的小伙伴们请注意了,我的博客开启了 MathJax 数学公式支持,MathJax 使用$标记数学公式的开始和结束.如果某条评论中出现了两个$,MathJax 会将两个$之 ...
- Kafka的partions和replication-factor参数的理解
Topic在Kafka中是主题的意思,生产者将消息发送到主题,消费者再订阅相关的主题,并从主题上拉取消息. 在创建Topic的时候,有两个参数是需要填写的,那就是partions和replicatio ...
- 八问WebSocket协议:为你快速解答WebSocket热门疑问
一.引言 WebSocket是一种比较新的协议,它是伴随着html5规范而生的,虽然还比较年轻,但大多主流浏览器都已经支持.它使用方面.应用广泛,已经渗透到前后端开发的各种场景中. 对http一问一答 ...
- Android 开发之v4库冲突问题解决方案说明
问题背景 Android Studio 开发时使用到了 GSYVideoPlayer 开源的播放器框架,配置信息如下: implementation 'com.shuyu:GSYVideoPlayer ...
- 一些关于StringAPI的题目
一:知识点 1.字符串"你好北京"中每个字符占用2个内存字节数.字符串底层由字符数组构成,每个字符占用内存2个字节. 2.重写toString 一般对象都有这个方法,目的是将对象按 ...
- 浅论各种调试接口(SWD、JTAG、Jlink、Ulink、STlink)的区别
JTAG协议 JTAG(Joint Test Action Group,联合测试行动小组)是一种国际标准测试协议(IEEE 1149.1兼容),主要用于芯片内部测试.现在多数的高级器件都支持JTAG协 ...
- 面试官: 说说看, 什么是 Hook (钩子) 线程以及应用场景?
文章首发自个人微信号: 小哈学Java 个人网站地址: https://www.exception.site/java-concurrency/java-concurrency-hook-thread ...