前端自动化less、scss、sass、stylus预处理器
yuyutoo 2024-10-12 00:01 4 浏览 0 评论
相信搞web开发的童鞋们;
多多少少都能写点css;
毕竟这玩意压根也称不上编程;
都是些固定写法死记硬背用就成了;
写css基本上都是体力活;
当然;今个不是要来讲css的;
而是要带领还在刀耕火种的使用css的童鞋们;
进入css预处理器时代;
先来段css代码;
为了直观这里直接以元素名命名class了;
.body {
background: #000;
color: #fff;
}
.body .p {
width: 100px;
height: 100px;
}
.body .p .a {
color: #eee;
}
因为css优先级的问题;
童鞋们相比对于这种一层一层的写法也是非常纠结;
每次写一个子级的样式;都要复制父级的一串选择器;
好了;第一上场的主角叫less;
这是一个只需要1分钟即可学会;
然后就能为我们的工作节省大量时间的东西;
还记得上篇文章我们安装了一个叫npm的包管理工具么;
后面我们都用cnpm代替了;
先来安装less;
cnpm install -g less
lessc -v
注意;这里是lessc;不是less;
好了;装完less;接着就是怎么用了;
找个空旷的地方;新建一个test.less文件;
把下面这段代码粘贴进去;
.body{
background: #000;
color: #fff;
.p{
width: 100px;
height: 100px;
.a{
color: #eee;
}
}
}
然后 cd 或者 git bash 到这;
运行下面编译less的命令;会生成一个test.css文件;
内容就和文章刚开始写那段css一样;
lessc test.less test.css
好了到这;我觉得就没必要讲了;
因为童鞋们扫了一眼后;就已经学会了less了;
就是简单的写成层级嵌套的的形式;
好处也很明显;一个选择器写一次就行了;
再也不用一层一层的复制父级class名了;
而且层级关系非常清晰;
还有两个重要的用法;这里给段示例;就肯定又懂了;
@base: #eee;
.a{
color: @base;
&:hover{
color: @base;
}
}
上面这段代码将生成如下css;
.a {
color: #eee;
}
.a:hover {
color: #eee;
}
那个@就是定义变量的意思;接着就是使用变量;
&: 后面跟的是伪元素类推还有:before和:after等;
别把这段复制进test.less啊;下面还要用;
更详细的就直接传送到官网吧:less官网
为什么不给个中文站?因为中文站翻译的跟没翻译差不多;
第二、第三个上场的主角叫scss和sass;
之所以两个一起上场;是因为他俩是父子关系;
先来安装个sass的包;
cnpm install -g npm-sass
把之前的那个test.less复制一份改名为 test2.scss
然后运行:
npm-sass test2.scss > test2.css
好了;scss你也学会了;完全跟less一样就行;
但是如果跟less一样;那就没必要讲了;
区别还是有的;而且更有一堆高级的用法;
首先可以 import 一个scss文件;
不同于css的import的是;scss用import最后会合并成一个文件;
然后;可以使用 $ 定义变量;把less中的@换成$就哦了;
比less强大的是;变量可以定义成数组;
更强大的是;连if、for、each、等判断和循环都可以;
以及 继承、函数、运算等等;
更详细的请点传送门:w3cplus中文教程
那sass和scss什么区别呢?
其实使用上没区别;scss 是 sass 3 引入新的语法;
但是sass继承了Ruby的语法;
就是不要花括号{ }和分号; ;靠缩进表示层级关系;后缀为.sass;
把之前的那个test.less复制一份改名为 test3.sass;
去掉花括号{ }和分号;;
.body
background: #000
color: #fff
.p
width: 100px
height: 100px
.a
color: #eee
然后运行
npm-sass test3.sass > test3.css
最后一个上场的叫Stylus;
和前面几位主角打过交道后;
到了stylus;我想说的就是;
把前面的那些代码去掉花括号、冒号、分号;
然后ok;stylus你也学会了;
光说不行;咱得走一遍溜溜;
cnpm install -g stylus
把之前的那个test.less复制一份改名为 test4.styl;
删掉花括号{ }、分号;、冒号:;
.body
background #000
color #fff
.p
width 100px
height 100px
.a
color #eee
然后运行
stylus test4.styl test4.css
更详细的文档传送门:stylus中文文档
ok;到这里;css的三种预处理器就讲解完了;
那选择恐惧症的童鞋们就该纠结了;
到底用那种好呢?其实看个人习惯;没有绝对标准;
不过;这里还是给出我的个人意见仅供参考;
stylus真是相当有创意;简洁干净;
相当满足懒人的需求;可以少打好多符号;
所以...
别急;这还有个但是;
但是;有花括号、分号、冒号;层级感更明显;更利于维护;
所以首先pass掉stylus;
sass明显比less更强大;功能更多;而学习成本并不高;
所以;接着pass掉less;
最后;前端框架界的楷模bootstrap4已经转向scss了;
就不需要我再废话了吧;
收工;买个回城卷轴;回我的被窝了;
-------------------------------------------------------------------------------------------------------
程序员交流QQ群:374604838
云服务器提供商:http://www.zunse.net
小编微信:woshiyixun
- 上一篇:Sass的安装 sas软件如何安装
- 下一篇:Sass 循环语句 sasdo循环
相关推荐
- 史上最全的浏览器兼容性问题和解决方案
-
微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...
-
- 平面设计基础知识_平面设计基础知识实验收获与总结
-
CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...
-
2025-02-21 16:01 yuyutoo
- 写作排版简单三步就行-工具篇_作文排版模板
-
和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...
- 写一个2048的游戏_2048小游戏功能实现
-
1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...
- 今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……
-
最近的天气暖和得让很多小伙伴们喊“热”!!! 昨天的气温到底升得有多高呢?你家有没有榜上有名?...
- CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式
-
之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...
- 你的自我界限够强大吗?_你的自我界限够强大吗英文
-
我的结果:A、该设立新的界限...
- 行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?
-
行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...
-
- 让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
-
去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...
-
2025-02-21 16:00 yuyutoo
- 今年国家综合性消防救援队伍计划招录消防员15000名
-
记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...
- 一起盘点最新 Chrome v133 的5大主流特性 ?
-
1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...
- 竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使
-
style="text-align:center;"data-mce-style="text-align:...
- 学物理能做什么?_学物理能做什么 卢昌海
-
作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...
-
- 你不知道的关于这只眯眼兔的6个小秘密
-
在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...
-
2025-02-21 16:00 yuyutoo
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)