首页技术文章正文

Stylus基本使用【黑马web前端】

更新时间:2019年07月26日 10时52分56秒 来源:黑马程序员论坛

介绍
这个哥们儿学名叫 stylus,是 CSS 的预处理框架。
CSS 预处理,顾名思义,预先处理 CSS。那 stylus 咋预先处理呢?stylus 给 CSS 添加了可编程的特性,也就是说,在 stylus 中可以使用变量、函数、判断、循环一系列 CSS 没有的东西来编写样式文件,执行这一套骚操作之后,这个文件可编译成 CSS 文件。
安装
首先,安装 stylus(确保之前已经安装 nodejs )。
[JavaScript] 纯文本查看 复制代码
$ npm install stylus


安装之后,运行 stylus -h 可查看帮助。
运行 stylus example.styl 可将 demo.styl 文件编译成 example.css 文件。
基本使用
一段简单的 stylus 代码:
[CSS] 纯文本查看 复制代码
$background-color = lightblue
add (a, b = a)
    a = unit(a, px)
    b = unit(b, px)
    a + b

.list-item
.text-box
    span
        background-color: $background-color
        margin: add(10)
        padding: add(10, 5)
    &:hover
        background-color: powderblue

编译后生成的 CSS 代码:
[CSS] 纯文本查看 复制代码
.list-item span,
.text-box span {
  background-color: #add8e6;
  margin: 20px;
  padding: 15px
}
.list-item:hover,
.text-box:hover {
  background-color: #b0e0e6;
}


由此我们看到了 stylus 代码以及由它编译而成的 CSS 代码,下面来一步一步看一看为啥编译成这样。
变量
[JavaScript] 纯文本查看 复制代码
$background-color = lightblue


上面的代码声明了变量 $background-color,并为其赋值 lightblue。
声明之后,就可以使用这个变量了:
[JavaScript] 纯文本查看 复制代码
span
    background-color: $background-color


翻译成 CSS 就是:
[CSS] 纯文本查看 复制代码
span{
    background-color: lightblue;
}


函数
[JavaScript] 纯文本查看 复制代码
add (a, b = a)
    a = unit(a, px)
    b = unit(b, px)
    a + b


代码声明了函数 add, add 接受两个参数 a 和 b,其中 b 的默认值是 a。
add 中调用了 stylus 的内置函数 unit,此处,unit 函数为 a 和 b赋予了单位 px。
最后将 a 和 b 相加,并返回结果,是的,你没有看错,没有 return,但是返回了结果。
return 居然是可以省略的,很任性了。
函数调用:
[JavaScript] 纯文本查看 复制代码
span
    margin: add(10)
    padding: add(10, 5)

翻译成 CSS 就是:
[CSS] 纯文本查看 复制代码
span {
    margin: 20px;
    padding: 15px;
}

选择器
[CSS] 纯文本查看 复制代码
.list-item
.text-box
    span
        background-color: $background-color
        margin: add(10)
        padding: add(10, 5)
    &:hover
        background-color: powderblue


这一段是与 CSS 代码长得最像的了,虽说最为相像,可有些差别还是一眼就能看出的。
比如没有了 CSS 的花括号,没有了 CSS 的分号,却多了一些奇奇怪怪的缩进,还有那个 & 是什么鬼?还 &:hover ???
预知后事如何,这次接着分解。
先说符号,这里提到的花括号和分号在stylus中是可以省略的,不仅如此,冒号也是可以省略的,color: powderblue 你可以写成 color powderblue,没有问题。
再说缩进,先提出两个有缩进关系的选择器,上面代码片段第二行的 .text-box 和第三行的 span,其实很容易理解,这哥俩写到 CSS 里面是这样的:
.text-box span{ ... }

即 span 是 .text-box 的子选择器,stylus 中以缩进表示这种关系,更加清晰明了,好看。
还有 &,这是个新鲜东西。它是父级的引用,还是来看代码。
stylus这样写:
[CSS] 纯文本查看 复制代码
.list-item
.text-box
    &:hover
        background-color: powderblue

翻译成 CSS 是这样:
[CSS] 纯文本查看 复制代码
.list-item:hover,
.text-box:hover {
  background-color: #b0e0e6;
}


相信代码中已经能很明确地体现出 & 父级引用的角色了。
同时,我们也不难看出,.list-item 和 .text-box 这两个同一级的选择器在 stylus 中是可以换行写的,只要保证缩进相同,它们就属于同一级的选择器。当然,沿用 CSS 的方式,将同一级的选择器用逗号分隔开在 stylus 中也是可以的。
总结
上面就是 stylus 的基本使用,普遍情况可以用上。


链接:https://www.jianshu.com/p/5fb15984f22d
来源:简书
简书著作权归作者所有

推荐了解热门学科

java培训 Python人工智能 Web前端培训 PHP培训
区块链培训 影视制作培训 C++培训 产品经理培训
UI设计培训 新媒体培训 产品经理培训 Linux运维
大数据培训 智能机器人软件开发




传智播客是一家致力于培养高素质软件开发人才的科技公司“黑马程序员”是传智播客旗下高端IT教育品牌。自“黑马程序员”成立以来,教学研发团队一直致力于打造精品课程资源,不断在产、学、研3个层面创新自己的执教理念与教学方针,并集中“黑马程序员”的优势力量,针对性地出版了计算机系列教材50多册,制作教学视频数+套,发表各类技术文章数百篇。

传智播客从未停止思考

传智播客副总裁毕向东在2019IT培训行业变革大会提到,“传智播客意识到企业的用人需求已经从初级程序员升级到中高级程序员,具备多领域、多行业项目经验的人才成为企业用人的首选。”

中级程序员和初级程序员的差别在哪里?
项目经验。毕向东表示,“中级程序员和初级程序员最大的差别在于中级程序员比初级程序员多了三四年的工作经验,从而多出了更多的项目经验。“为此,传智播客研究院引进曾在知名IT企业如阿里、IBM就职的高级技术专家,集中研发面向中高级程序员的课程,用以满足企业用人需求,尽快补全IT行业所需的人才缺口。

何为中高级程序员课程?

传智播客进行了定义。中高级程序员课程,是在当前主流的初级程序员课程的基础上,增加多领域多行业的含金量项目,从技术的广度和深度上进行拓展“我们希望用5年的时间,打造上百个高含金量的项目,覆盖主流的32个行业。”传智播客课程研发总监于洋表示。




黑马程序员热门视频教程【点击播放】

Python入门教程完整版(懂中文就能学会) 零起点打开Java世界的大门
C++| 匠心之作 从0到1入门学编程 PHP|零基础入门开发者编程核心技术
Web前端入门教程_Web前端html+css+JavaScript 软件测试入门到精通


在线咨询 我要报名
和我们在线交谈!