coffeescript的地址:http://coffee-script.org/
nodejs的安装,我们在前面一篇博客已经介绍到,地址:http://my.oschina.net/u/2352644/blog/487488
1.安装(无环境,不编程)
我们看到介绍,coffee就是尝试用简洁的方式展示 JavaScript 优秀的部分,是一个实用的 Node.js 工具. 不过编译器并不依赖 Node, 而是能运行于任何 JavaScript 执行环境,用过npm安装。
我们开始安装:我的是windows系统,nodejs通过上面咱们是要安装好的
1.win键+r 输入cmd 回车
2.我的nodejs安装目录 (d:nodejs ) 转到d盘 nodejs目录
d:
cd nodejs
3.node -v 确保nodejs安装
node -v
4.npm -v 确保npm安装,npm和nodejs已经集成
npm -v
5.npm install coffee-script 安装的coffee会在nodejs目录的node_modules下
npm install -g coffee-script
-g 的g是global意思,表示全局安葬,输入下面名利
coffee -v
输出coffee版本,表示安装成功!
我这里在nodejs的nodejs下已经看见了coffee模块了。我们下一步进行coffee的测试输出,类似hello world 的输出!
2.用法(等同于hello world 的输出)
我们在用法上看到各种命令的介绍,好心烦,不看了,我们直接看给的例子,一个个命令行测试就好了!
我们在开始就知道,coffee是用简单的语法编译成js的,这一刻就可以这么理解
js 创建变量是 var aa=123;
coffee 创建变量可能这么写 v aa=123
的写法了,对js的语言进行了映射似的精简。
我们在官网的概述看见了coffee的代码写法,我们复制下来,保存成 start.coffee 文件,为进行的coffee实现!
我们在nodejs目录下创建coffee文件夹,下面创建start.coffee 文件。
我们通过任何编辑器打开.coffee文件,里面代码如下:
# 赋值: number = 42 opposite = true # 条件: number = -42 if opposite # 函数: square = (x) -> x * x # 数组: list = [1, 2, 3, 4, 5] # 对象: math = root: Math.sqrt square: square cube: (x) -> x * square x # Splats: race = (winner, runners...) -> print winner, runners # 存在性: alert "I knew it!" if elvis? # 数组 推导(comprehensions): cubes = (math.cube num for num in list)
什么东西?我们根据教程,对这个文件编译处理。
我们转到放coffee文件的目录
cd coffee
执行coffee的编译命令
coffee -c start.coffee
-c表示编译coffee文件,后面就是我们创建的coffee文件。
编译后的代码如下:
// Generated by CoffeeScript 1.9.3 (function() { var cubes, list, math, num, number, opposite, race, square, slice = [].slice; number = 42; opposite = true; if (opposite) { number = -42; } square = function(x) { return x * x; }; list = [1, 2, 3, 4, 5]; math = { root: Math.sqrt, square: square, cube: function(x) { return x * square(x); } }; race = function() { var runners, winner; winner = arguments[0], runners = 2 <= arguments.length ? slice.call(arguments, 1) : []; return print(winner, runners); }; if (typeof elvis !== "undefined" && elvis !== null) { alert("I knew it!"); } cubes = (function() { var i, len, results; results = []; for (i = 0, len = list.length; i < len; i++) { num = list[i]; results.push(math.cube(num)); } return results; })(); }).call(this);
对比概览发现多了东西如下,
(function() { }).call(this);
我们测试一下这个作用吗,我们创建一个html页面,里面写入如下的js代码:
(function() { alert("我的外层干什么的?") }).call(this);
html整个代码如下
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/> <style type="text/css"> *{ margin:0; padding:0;} </style> <script src="js/jquery.js"></script> <title>coffee</title> </head> <body> </body> <script type="text/javascript"> (function() { alert("我的外层干什么的?") }).call(this); </script> </html>
会执行alert,看来这个外层包裹和
(function() { })();
同样的作用,都是立即执行的匿名函数,我们知道call是调用并且执行方法,里面的this是js的指针,指向的是window全局对象
if(this===window){alert(this)}
直接放在script下的this是指向window的,this作为上下文指针受环境影响作出不同指向。
coffee把编译的代码放在立即执行函数就是为了防止污染。
3.思考
我们看见上面的编译,瞬间就想到了less和sass,这两个技术不就是最后编译成css吗?css的动态预处理技术。同样coffee也是做了类似的工作,通过新的定义去书写,最后生成js文件。
less和sass里面支持css的写法,但是coffee里面不支持js的书写,不过有人说的很对,这三种可归为脱了裤子放屁!!!
less和sass是嵌入了语法的css,不过我觉得吧,就算你掌握的这种写法,也未必写的过用css的,页面是实现不单单是css的书写,还有对布局的掌握,就算这些不考虑?你确定能用less写的比我快?有人说修改维护快,自己写的不灵活赖我咯!哈哈哈!浪费时间是真的,你想想他学了less,浪费了很多的精力,但是在开发中并没有什么收益,还要有面子,所有你懂得他要怎么和你吹了!less和sass绝对的浪费时间和换取不到什么收益的东西,如果你用了,公司强制了,呵呵吧!
纯脱了裤子放屁的东西还要用,还要你花时间学,让你连搬砖都非得背个登山包能么么哒吗!
说说coffee吧!我都是实话实说,想用好,js必须过关,你js都只能写2行半,你还要简写你觉得你不是扯淡吗?为我们避免了很多js书写的不规范,!
4.语言
大家打开官网,语言手册左侧是coffee代码,右侧是js代码,会js的看起来不难,不会的就学完右侧的js再回来写coffee吧!