2013-07-31 19:13:11 -05:00
---
language: coffeescript
contributors:
- ["Tenor Biel", "http://github.com/L8D"]
2014-03-14 18:18:23 +00:00
- ["Xavier Yao", "http://github.com/xavieryao"]
2013-07-31 19:13:11 -05:00
filename: coffeescript.coffee
---
2014-02-05 21:37:17 +08:00
CoffeeScript is a little language that compiles one-to-one into the equivalent JavaScript, and there is no interpretation at runtime.
As one of the succeeders of JavaScript, CoffeeScript tries its best to output readable, pretty-printed and smooth-running JavaScript codes working well in every JavaScript runtime.
2014-01-29 21:34:56 -05:00
See also [the CoffeeScript website ](http://coffeescript.org/ ), which has a complete tutorial on CoffeeScript.
2014-09-08 13:08:28 +02:00
```coffeescript
2013-07-31 19:13:11 -05:00
# CoffeeScript is a hipster language.
# It goes with the trends of many modern languages.
2014-04-14 11:04:44 -07:00
# So comments are like Ruby and Python, they use number symbols.
2013-07-31 19:13:11 -05:00
###
Block comments are like these, and they translate directly to '/ *'s and '* /'s
for the resulting JavaScript code.
2014-09-14 13:18:43 -06:00
You should understand most of JavaScript semantics
2013-07-31 19:13:11 -05:00
before continuing.
###
# Assignment:
number = 42 #=> var number = 42;
opposite = true #=> var opposite = true;
# Conditions:
number = -42 if opposite #=> if(opposite) { number = -42; }
# Functions:
square = (x) -> x * x #=> var square = function(x) { return x * x; }
2014-02-05 21:37:17 +08:00
fill = (container, liquid = "coffee") ->
"Filling the #{container} with #{liquid}..."
#=>var fill;
#
#fill = function(container, liquid) {
# if (liquid == null) {
# liquid = "coffee";
# }
# return "Filling the " + container + " with " + liquid + "...";
#};
2013-07-31 19:13:11 -05:00
# Ranges:
list = [1..5] #=> var list = [1, 2, 3, 4, 5];
# Objects:
math =
root: Math.sqrt
square: square
cube: (x) -> x * square x
#=> var math = {
# "root": Math.sqrt,
# "square": square,
# "cube": function(x) { return x * square(x); }
#}
# Splats:
race = (winner, runners...) ->
print winner, runners
2014-02-05 21:37:17 +08:00
#=>race = function() {
# var runners, winner;
# winner = arguments[0], runners = 2 <= arguments.length ? __slice.call(arguments, 1) : [];
# return print(winner, runners);
#};
2013-07-31 19:13:11 -05:00
# Existence:
alert "I knew it!" if elvis?
#=> if(typeof elvis !== "undefined" && elvis !== null) { alert("I knew it!"); }
# Array comprehensions:
2014-02-05 21:37:17 +08:00
cubes = (math.cube num for num in list)
#=>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;
# })();
foods = ['broccoli', 'spinach', 'chocolate']
eat food for food in foods when food isnt 'chocolate'
#=>foods = ['broccoli', 'spinach', 'chocolate'];
#
#for (_k = 0, _len2 = foods.length; _k < _len2; _k++) {
# food = foods[_k];
# if (food !== 'chocolate') {
# eat(food);
# }
#}
2013-07-31 19:13:11 -05:00
```
2014-05-12 12:47:35 -07:00
## Additional resources
- [Smooth CoffeeScript ](http://autotelicum.github.io/Smooth-CoffeeScript/ )
2014-05-12 14:12:39 -07:00
- [CoffeeScript Ristretto ](https://leanpub.com/coffeescript-ristretto/read )