课程表

CoffeeScript 语法

CoffeeScript 类和对象

CoffeeScript 字符串

CoffeeScript 数组

CoffeeScript 日期和时间

CoffeeScript 数学

CoffeeScript 方法

CoffeeScript 元编程

CoffeeScript jQuery

CoffeeScript 正则表达式

CoffeeScript 网络

CoffeeScript 设计模式

CoffeeScript 数据库

CoffeeScript 测试

工具箱
速查手册

一切都是表达式

当前位置:免费教程 » JS/JS库/框架 » CoffeeScript

读者大概有注意到上面的代码 CoffeeScript 函数是不需要写 return 语句的, 但是也会返回最终的结果。 CoffeeScript 编译器会尽可能保证语言中所有的表达式都可以被当作表达式使用。 观察一下下面的函数, return 是怎样尽可能地插入到执行的分支当中的。

CoffeeScript:
  1. grade = (student) ->
  2. if student.excellentWork
  3. "A+"
  4. else if student.okayStuff
  5. if student.triedHard then "B" else "B-"
  6. else
  7. "C"
  8.  
  9. eldest = if 24 > 21 then "Liz" else "Ike"
编译成JS:
  1. var eldest, grade;
  2.  
  3. grade = function(student) {
  4. if (student.excellentWork) {
  5. return "A+";
  6. } else if (student.okayStuff) {
  7. if (student.triedHard) {
  8. return "B";
  9. } else {
  10. return "B-";
  11. }
  12. } else {
  13. return "C";
  14. }
  15. };
  16.  
  17. eldest = 24 > 21 ? "Liz" : "Ike";

尽管函数总是会自动 return 其最终的值, 你可以在函数体前面显式地写上 (return value), 这个做法也是值得借鉴的, 前提是你明确你在做的事情是什么。

由于变量声明是生成在作用域顶部, 所以在表达式内部也可以写赋值, 即便是前面没写到过的变量。

CoffeeScript:
  1. six = (one = 1) + (two = 2) + (three = 3)
编译成JS:
  1. var one, six, three, two;
  2.  
  3. six = (one = 1) + (two = 2) + (three = 3);

有些代码在 JavaScript 当中要写不少的语句, 而在 CoffeeScript 中只是表达式的一部分, 这些代码的编译结果会自动生成一个闭包。 这个写法很有用, 比如把列表解析的结果赋值给变量:

CoffeeScript:
  1. # 前十个全局属性(变量).
  2.  
  3. globals = (name for name of window)[0...10]
编译成JS:
  1. var globals, name;
  2.  
  3. globals = ((function() {
  4. var _results;
  5. _results = [];
  6. for (name in window) {
  7. _results.push(name);
  8. }
  9. return _results;
  10. })()).slice(0, 10);

结果是一些原来明确是语句的东西也可以像, 比如把 try/catch 语句直接传给函数调用:

CoffeeScript:
  1. alert(
  2. try
  3. nonexistent / undefined
  4. catch error
  5. "And the error is ... #{error}"
  6. )
编译成JS:
  1. var error;
  2.  
  3. alert((function() {
  4. try {
  5. return nonexistent / void 0;
  6. } catch (_error) {
  7. error = _error;
  8. return "And the error is ... " + error;
  9. }
  10. })());
有一些 JavaScript 语句是不能编译到表达式的对应的语义的, 比如 break, continue 和 return。 如果你的代码当中用到了它们, CoffeeScript 是不会尝试去进行转换的。
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号