1.方法

函数  Stylus强大之处就在于其内置的语言函数定义。其定义与混入(mixins)一致;却可以返回值。

默认参数

可选参数往往有个默认的给定表达。在Stylus中,我们甚至可以超越默认参数。

例如:

add(a, b = a)
a + b add(10, 5)
// => 15 add(10)
// => 20

注意:因为参数默认是赋值,我们可可以使用函数调用作为默认值。

add(a, b = unit(a, px))
a + b

函数体

我们可以把简单的add()方法更进一步。通过内置unit()把单位都变成px, 因为赋值在每个参数上,因此,我们可以无视单位换算。

add(a, b = a)
a = unit(a, px)
b = unit(b, px)
a + b add(15%, 10deg)
// => 25
多个返回值

Stylus的函数可以返回多个值,就像你给变量赋多个值一样。

例如,下面就是一个有效赋值:

sizes = 15px 10px

sizes[0]
// => 15px
类似的,我们可以在函数中返回多个值: sizes()
15px 10px sizes()[0]
// => 15px
有个小小的例外就是返回值是标识符。例如,下面看上去像一个属性赋值给Stylus(因为没有操作符)。

swap(a, b)
b a
为避免歧义,我们可以使用括号,或是return关键字。 swap(a, b)
(b a) swap(a, b)
return b a

条件  使用yes和no代替true 和false 注意:yesno并不是布尔值。本例中,它们只是简单的未定义标识符。

stringish(val)
if val is a 'string' or val is a 'ident'
yes
else
no
使用: stringish('yay') == yes
// => true stringish(yay) == yes
// => true stringish(0) == no
// => true
其他例子:
compare(a, b)
if a > b
higher
else if a < b
lower
else
equal

变量函数 即把函数当作变量传递到新的函数中

invoke(a, b, fn)
fn(a, b)

参数

arguments是所有函数体都有的局部变量,包含传递的所有参数。

sum()
n = 0
for num in arguments
n = n + num sum(1,2,3,4,5)
// => 15

哈希示例

定义get(hash, key)方法,用来返回key值或null. 我们遍历每个键值对,如果键值匹配,返回对应的值。

get(hash, key)
return pair[1] if pair[0] == key for pair in hash
下面例子可以证明,语言函数模样的Stylus表达式具有更大的灵活性。 hash = (one 1) (two 2) (three 3) get(hash, two)
// => 2 get(hash, three)
// => 3 get(hash, something)
// => null

2. 关键字参数

查看函数或混合书写中接受的参数,可以使用p()方法。

3.内置方法

red(color)      green(color)      blue(color)   alpha(color)  返回color中的颜色比重,透明度比重

alpha(#fff)
// => 1

dark(color)  检查color是否是暗色   light(color)  检查color是否是亮色  hue(color)  返回给定color的色调   saturation(color)  返回给定color的饱和度  lightness(color)  返回给定color的亮度

hue(hsla(50deg, 100%, 80%))
// => 50deg saturation(hsla(50deg, 100%, 80%))
// => 100% lightness(hsla(50deg, 100%, 80%))
// => 80%

push(expr,args...)   别名append()  unshift(expr,args) 别名prepend()

nums = 1 2
push(nums, 3, 4, 5) nums
// => 1 2 3 4 5
nums = 4 5 unshift(nums, 3, 2, 1) nums
// => 1 2 3 4 5

keys(pairs),values(pairs)  返回Paris中的键 值。

pairs = (one 1) (two 2) (three 3)
keys(pairs)
// => one two three

typeof(node)  别名有type-oftype。  unit(unit[, type])

返回unit类型的字符串或空字符串,或者赋予type值而无需单位转换。

type(12)
// => 'unit' typeof(12)
// => 'unit' typeof(#fff)
// => 'rgba' type-of(#fff)
// => 'rgba' unit(10)
// => '' unit(15in)
// => 'in' unit(15%, 'px')
// => 15px unit(15%, px)
// => 15px

match(pattern, string) 检测string是否匹配给定的pattern.  abs(unit) 绝对值   ceil(unit)floor(unit) 向上,下取整  round(unit) 四舍五入取整  even(unit)是否为偶数 odd(unit) 是否为奇数

match('^foo(bar)?', 'bar')
// => false
match('^foo(bar)?', foobar)
// => true

此外还有sum, avg. length().

join(delim, vals...) 给定vals使用delim连接

join(', ', foo, bar, baz)
// => "foo, bar, baz"

invert(color) 颜色反相。红绿蓝颜色反转,透明度不变。  unquote(str | ident)  给定str引号去除,返回Literal节点。

s(fmt, …) s()方法类似于unquote(),不过后者返回的是Literal节点,而这里起接受一个格式化的字符串,非常像C语言的sprintf(). 目前,唯一标识符是%s.

unquote("sans-serif")
// => sans-serif s('bar()');
// => bar() s('bar(%s)', 'baz');
// => bar("baz") s('bar(%s)', baz);
// => bar(baz) s('rgba(%s, %s, %s, 0.5)', 255, 100, 50);
// => rgba(255, 100, 50, 0.5) s('bar(%Z)', 15px);
// => bar(%Z) s('bar(%s, %s)', 15px);
// => bar(15px, null)

operate(op,left,right) 在leftright操作对象上执行给定的op.

op = '+'
operate(op, 15, 5)
// => 20

warm(msg) 使用给定的error警告,并不退出。  error(msg)伴随给定的错误msg退出。last(expr) 返回给定expr的最后一个值。

p(expr) 检查,类似得到确定信息

p(fonts)
inspect: Arial, sans-serif

opposite-position(positions) 返回给定position相反内容

opposite-position(top left)
// => bottom right

image-size(path) 返回指定path图片的widthheight. 向上查找路径的方法和@import一样,paths设置的时候改变。

width(img)
return image-size(img)[0] height(img)
return image-size(img)[1] image-size('tux.png')
// => 405px 250px image-size('tux.png')[0] == width('tux.png')
// => true

add-property(name, expr) 使用给定的expr为最近的块域添加属性name

something()
add-property('bar', 1 2 3)
s('bar') body
foo: something()
真实面目: body {
bar: 1 2 3;
foo: bar;
}
接下来,“神奇”的current-property局部变量将大放异彩,这个变量自动提供给函数体,且包含当前属性名和值的表达式。 例如,我们使用p()检查这个局部变量,我们可以得到: p(current-property)
// => "foo" (foo __CALL__ bar baz) p(current-property[0])
// => "foo" p(current-property[1])
// => foo __CALL__ bar baz

Stylus支持name...形式的其余参数。这些参数可以消化传递给混写或函数的参数们。这在处理浏览器私有属性,如-moz-webkit的时候很管用。

下面这个例子中,所有的参数们(1px, 2px, ...)都被一个args参数给简单消化了:

box-shadow(args...)
-webkit-box-shadow args
-moz-box-shadow args
box-shadow args #login
box-shadow 1px 2px 5px #eee
生成为: #login {
-webkit-box-shadow: 1px 2px 5px #eee;
-moz-box-shadow: 1px 2px 5px #eee;
box-shadow: 1px 2px 5px #eee;
}

我们想指定特定的参数,如x-offset,我们可以使用args[0], 或者,我们可能希望重新定义混入。

2.注释

Stylus支持三种注释,单行注释,多行注释,以及多行缓冲注释。

单行:跟JavaScript一样,双斜杠,CSS中不输出。  多行:多行注释看起来有点像CSS的常规注释。然而,它们只有在compress选项未启用的时候才会被输出。

多行缓冲:跟多行注释类似,不同之处在于开始的时候,这里是/*!. 这个相当于告诉Stylus压缩的时候这段无视直接输出。

/*!
* 给定数值合体
*/ add(a, b)
a + b

3.条件

if/else 同一般的语言

除非 unless , 其基本上与if相反,本质上是(!(expr)).

下面这个例子中,如果disable-padding-overrideundefinedfalsepadding将被干掉,显示margin代替之。但是,如果是truepadding将会如期继续输出padding 5px 10px.

disable-padding-override = true

unless disable-padding-override is defined and disable-padding-override
padding(x, y)
margin y x body
padding 5px 10px

后缀条件

Stylus支持后缀条件,这就意味着ifunless可以当作操作符;当右边表达式为真的时候执行左边的操作对象。

例如,我们定义negative()来执行一些基本的检查:

negative(n)
error('无效数值') unless n is a 'unit'
return yes if n < 0
no
pad(types = margin padding, n = 5px)
padding unit(n, px) if padding in types
margin unit(n, px) if margin in types body
pad() body
pad(margin) body
apply-mixins = true
pad(padding, 10) if apply-mixins
生成为: body {
padding: 5px;
margin: 5px;
}
body {
margin: 5px;
}
body {
padding: 10px;
}

4.迭代

Stylus允许你通过for/in对表达式进行迭代形式如下:

for <val-name> [, <key-name>] in <expression>
body
fonts = Impact Arial sans-serif
for font, i in fonts
foo i font
生成为: body {
foo: 0 Impact;
foo: 1 Arial;
foo: 2 sans-serif;
}

stylus笔记(二)的更多相关文章

  1. 《CMake实践》笔记二:INSTALL/CMAKE_INSTALL_PREFIX

    <CMake实践>笔记一:PROJECT/MESSAGE/ADD_EXECUTABLE <CMake实践>笔记二:INSTALL/CMAKE_INSTALL_PREFIX &l ...

  2. jQuery源码笔记(二):定义了一些变量和函数 jQuery = function(){}

    笔记(二)也分为三部分: 一. 介绍: 注释说明:v2.0.3版本.Sizzle选择器.MIT软件许可注释中的#的信息索引.查询地址(英文版)匿名函数自执行:window参数及undefined参数意 ...

  3. Mastering Web Application Development with AngularJS 读书笔记(二)

    第一章笔记 (二) 一.scopes的层级和事件系统(the eventing system) 在层级中管理的scopes可以被用做事件总线.AngularJS 允许我们去传播已经命名的事件用一种有效 ...

  4. Python 学习笔记二

    笔记二 :print 以及基本文件操作 笔记一已取消置顶链接地址 http://www.cnblogs.com/dzzy/p/5140899.html 暑假只是快速过了一遍python ,现在起开始仔 ...

  5. WPF的Binding学习笔记(二)

    原文: http://www.cnblogs.com/pasoraku/archive/2012/10/25/2738428.htmlWPF的Binding学习笔记(二) 上次学了点点Binding的 ...

  6. webpy使用笔记(二) session/sessionid的使用

    webpy使用笔记(二) session的使用 webpy使用系列之session的使用,虽然工作中使用的是django,但是自己并不喜欢那种大而全的东西~什么都给你准备好了,自己好像一个机器人一样赶 ...

  7. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

  8. 《MFC游戏开发》笔记二 建立工程、调整窗口

    本系列文章由七十一雾央编写,转载请注明出处.  http://blog.csdn.net/u011371356/article/details/9300383 作者:七十一雾央 新浪微博:http:/ ...

  9. JavaScript基础笔记二

    一.函数返回值1.什么是函数返回值    函数的执行结果2. 可以没有return // 没有return或者return后面为空则会返回undefined3.一个函数应该只返回一种类型的值 二.可变 ...

  10. [Firefly引擎][学习笔记二][已完结]卡牌游戏开发模型的设计

    源地址:http://bbs.9miao.com/thread-44603-1-1.html 在此补充一下Socket的验证机制:socket登陆验证.会采用session会话超时的机制做心跳接口验证 ...

随机推荐

  1. 使用PyQT开发图形界面程序

    环境 python:v3.3 PyQT:v4.10.4 注意问题: 在主文件前面加入,否则当前的工程模块无法找到 import sys sys.path.append(".") 入 ...

  2. Cookie:解决HTTP协议无保存状态

    客户端 Cookie会根据从服务器端发送的相应报文内一个叫Set-Cookie的首部字段信息,通知客户端保存Cookie.当下次客户端再往该服务器发送请求时,客户端会自动在请求报文中加入Cookie值 ...

  3. Linux下一台服务器Redis主从复制(master-slave)配置

    主从概念 ⼀个master可以拥有多个slave,⼀个slave⼜可以拥有多个slave,如此下去,形成了强⼤的多级服务器集群架构 master用来写数据,slave用来读数据,经统计:网站的读写比率 ...

  4. java框架之SpringBoot(16)-分布式及整合Dubbo

    前言 分布式应用 在分布式系统中,国内常用 Zookeeper + Dubbo 组合,而 SpringBoot 推荐使用 Spring 提供的分布式一站式解决方案 Spring + SpringBoo ...

  5. cocos中FPS数值的含义

    在cocos2d-x 2.x ,大家都看到了左下角的FPS变成3行,多了两行数据. 1.最上面一行是指的当前场景的渲染批次.(简单理解为需要渲染多少个贴图出来) 2.中间一行是渲染每一帧需要的时间. ...

  6. 使用PageHelper插件分页结合mybatis返回的列表个数不对问题解决

    问题描述:spring mvc+mybatis项目中,当使用PageHelper插件进行分页查询时,查到的总数据量值是正确的,但是查询当前页返回的列表个数不对.比如每页查询10条,返回2条或者3条.r ...

  7. OOP面向对象编程(下)

    我们怎么去模拟重载,在javasceipr中我们可以通过参数的类型区别或者数量的区别,来去让同样一个函数名字,可以根据不同的参数列表的情况来去调用相应的函数. javascript中函数类型是不确定的 ...

  8. mysql迁移到data下

    http://www.jb51.net/article/47897.htm 由于yum安装mysql的时候,数据库的data目录默认是在/var/lib下,出于数据安全性的考虑需要把它挪到/data分 ...

  9. 自动生成简单四则运算的C语言程序

    该程序是在博客园里面找的,具体是谁的找了半天没找到,无法提供它原本的链接.由于自己写的过于简单,且有一些功能暂时无法实现,所以就找了一个来应付作业,望原谅.在这个程序的源码中我改了一个错误的地方,源码 ...

  10. pjax转发

    pjax几大特点: 1.异步(ajax) 2.地址栏改变路径 3.实现前进和后退back和forword 如何解决:地址变了之后,万一F5刷新的问题,主要是通过后台判断是否为pjax请求,是的话做个标 ...