stylus入门教程,在webstorm中配置stylus

stylus特点

富于表现力、具有健壮性、功能丰富、动态编码

不需要写CSS的冒号、分号、大括号

和LESS、SASS功能类似,会这些的入手很快

安装

  1. 安装node+npm环境

  2. 命令行全局安装stylus

    cnpm i stylus@latest -g
  3. 可以在命令行输入 stylus -h 查看有哪些可以用的命令

使用

想将assets/css目录下的所有.styl文件编译成css怎么办?
stylus -c assets/css/
只想将assets/css/index.styl 编译成assets/css/index.css?
stylus -c assets/css/index.styl assets/css/index.css
想将assets/css/index.css 编译成assets/css/index.styl?
stylus -C assets/css/index.css 
不想这么麻烦的用命令怎么办?

使用webstorm设置如图可以自动将.styl文件转成.css文件
1475079-20180928114151966-1510440473.png
1475079-20180928114156206-149130584.png

注意第二张图是默认配置,无需修改,直接确定。
如果配置都是空的,可以安装我的配置填写。
如果Program项出现红色报错!是因为node环境有问题或者没有全局安装stylus
接下来只需要编写.styl文件就会自动编译出.css文件。如图

1475079-20180928114219821-361513935.png

vue中使用stylus, 命令行中输入
cnpm i stylus --save-dev 
在 .vue文件中使用, 添加使用 scoped 属性表示样式只对当前组件有效
<style scoped lang="stylus">
  html,body
    margin 0
    padding 0
    div
       color #333
</style>

stylus语法

#### (一)选择器

  • 1.冒号,分号,大括号可写可不写

  • 2.后代关系用相同缩进表示

  • 3.父子关系用 >表示

  • 4.伪类元素用 & 表示其宿主元素

  • 5.属性写在前, 嵌套子元素样式写在后

  • 6.分组选择器用相同缩进即可, 如 +a +span +span

1475079-20180928114233800-1608990562.png

#### (二)变量

1.定义变量并赋值(建议用$作为变量前缀), 如$width=3px

2.定义函数(arguments为内置所有参数, 也可自定义参数), border() $width dashed #foo

3.函数参数可以写默认值,类似于es6的解构赋值, 如 padding(top=1px,right=2px)

3.方法名加() 为调用函数,如 border()

4.建议变量定义在最上面, 然后是函数, 然后才是代码. 最好的方式是变量和函数定义成单独的文件, 然后通过@import variable.styl 导入

5.使用@height 会冒泡查找值, 如自身有此属性则获取该属性值; 否则层层向上查找该属性, 如果都没有则报错

6.可以使用运算符进行计算

7.z-index 1 unless @z-index 表示默认 z-index=1 除非 @z-index 存在

1475079-20180928114307230-560831891.png

(三)插值

1.实现类似 autoprefixer.css 的效果给兼容属性加前缀

2.使用循环 for in 减少代码量

3.使用 if-else 判断逻辑

1475079-20180928114313497-457654958.png

(四)运算符
[]
! ~ + -
is defined
** * / %
+ -
... ..
<= >= < >
in
== is != is not isnt
is a
&& and || or
?:
= := ?= += -= *= /= %=
not
if unless
(五)内置函数
函数实例说明
unit(14%,px)14px直接用第二个参数替换第一个参数的
abs(-5px)5px
ceil(2.3px)3px向上取整
floor(2.6px)2px向下取整
round(2.6px)3px四舍五入取整
min(1,2)1
max(1,2)2
even(3)false是否为偶数
odd(3)true是否为奇数
sum(1 2 3)6
avg(1 2 3)2
join(‘,’,1 2 3)1 2 3使用第一个参数为连接符将后面数组连接
length(1 2 3 4)4
image-size(‘aa.png’)20px 30px获取图片宽高
(六)尾参数…

1.可以使用 args... 或者 arr... 等接受所有参数; 前面也可以单个接受参数; 但是 尾参数写法只能作为最后一个参数

2.也可以使用 args[0] 或者 arguments[0] 这种下标的方式访问

3.args... 会忽略 , ;如果希望不忽略请使用 arguments

1475079-20180928114323838-1378463909.png

(七)@extend继承

1.使用 @extend 将公共样式抽取, 用子类继承; 在html中可以少写一个类名 ,如 class="btn btn-primary" 只需要写成 class="btn-primary" 
1475079-20180928114329855-1703172947.png

转载于:https://www.cnblogs.com/wenqiangit/p/9717715.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值