前端开发之路-coffeescript环境搭建

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吧!









你可能感兴趣的:(CoffeeScript)