coffeeScript是一种轻量级的编程语言,能够用编译器生成原生javascript代码。它简化了许多javascript繁琐的方式,可让你用简单的方式直接使用一行程序表明javascript多行代码,并且编译后还会根据最佳实践
优化javascript代码。它的语法像是python
和ruby
的混合,不用括号控制排版,直接用缩进表示。建议初学者一边写coffeescript
,一边对照生成的javascript
代码,能够很快的了解coffeescript
的意义。 浏览器最后执行的仍是编译后的javascript
代码。javascript
首先来看一个 coffeescript
demo:java
if elvis alert "oh no" elvis = 3
编译成 javascript
代码以后:python
if (elvis){ alert("oh no"); elvis = 3; }
看上面的coffee代码和js代码,js中的圆括号被去掉了,画括号也去掉了,分号;
也去掉了。编程
再好比:c#
if elvis alert "oh no" elvis = 3
编译成 javascript
代码以后:浏览器
if (elvis){ alert("oh no"); } elvis = 3;
最后一句代码缩进方式不一样,致使最终编译的js也不同,coffee就是根据tab缩进
来进行排版的。ruby
声明函数时coffee默认会把最后一行做为函数的返回值,能够不加return
,若是返回值为空,能够加上return
。编程语言
例如:函数
fill = (x) -> x * x
编译后的js为:优化
var fill; fill = function(x){ return x * x; }
这是coffe中最爱的一点,由于javascript中没有相似c#
中的string.Format()
方法,拼接很长的字符串时代码看起来可读性不好。
# 这是cofee的注释 eat = (x) -> alert "I eat #{x}!" eat food for food in ['toast', 'cheese', 'wine']
编译后的js代码:
var eat, food, _i, _len, _ref; eat = function(x) { return alert("I eat " + x + "!"); }; _ref = ['toast', 'cheese', 'wine']; for (_i = 0, _len = _ref.length; _i < _len; _i++) { food = _ref[_i]; eat(food); }
这里能够看出来使用coffee有多省事了吧。
coffee有一个像java同样的...
的语法:
# ... 表示区间 numbers = [0,1,2,3,4,5,6,7,8,9] copy = numbers[0...numbers.length] middle = numbers[3...6]
==
和 !=
之间的比较在coffee中没有==
,一概使用===
,因此也就没有!=
,只有!==
。javascript中==
和===
的区别是:
三等操做符
===
用来判断两个变量是否相等,相等的前提是一样的类型和一样的值。
具体请参考个人另外一篇文章。
coffee可使用?
来判断参数是否已定义或是null
值,例如:
if elvis? alert "oh no" elvis = 3
编译后的js代码:
var elvis; if (typeof elvis !== "undefined" && elvis !== null) { alert("oh no"); elvis = 3; }