2014-08-11 08:02:06 +00:00
---
contributors:
- ["Tenor Biel", "http://github.com/L8D"]
- ["Xavier Yao", "http://github.com/xavieryao"]
translators:
- ["Frederik Ring", "https://github.com/m90"]
2014-08-21 11:53:07 +00:00
- ["Philipp Fischbeck", "https://github.com/PFischbeck"]
2014-08-11 08:02:06 +00:00
---
2014-08-20 17:40:34 +00:00
CoffeeScript ist eine kleine Sprache, die eins zu eins nach JavaScript übersetzt wird - es findet keine Interpretation zur Laufzeit statt.
Als Nachfolger von JavaScript konzipiert, gibt CoffeeScript sein Bestes, lesbaren, gut formatierten und sauber laufenden JavaScript-Code zu erzeugen, der in jeder JavaScript-Laufzeit einwandfrei funktioniert.
2014-08-11 08:02:06 +00:00
Auf [der CoffeeScript Website ](http://coffeescript.org/ ) gibt es ein ausführliches Tutorial.
``` coffeescript
# CoffeeScript ist eine dieser Sprachen für "Hipster"
# und folgt daher vielen Trends und Einflüssen aus modernen Sprachen.
# Kommentare werden daher wie in Ruby und Python mit Hashes gekennzeichnet
###
2014-08-20 17:40:34 +00:00
Kommentarblöcke sehen aus wie diese und werden direkt nach '/ *'s und '* /'s
im erzeugten JavaScript umgewandelt.
2014-08-11 08:02:06 +00:00
2014-08-20 17:40:34 +00:00
Vorweg: bevor du mit CoffeeScript anfängst, solltest du bereits einen guten
Überblick über die Sprache JavaScript haben.
2014-08-11 08:02:06 +00:00
###
# Zuweisung:
number = 42 #=> var number = 42;
opposite = true #=> var opposite = true;
# Bedingungen:
number = -42 if opposite #=> if(opposite) { number = -42; }
# Funktionen:
square = (x) -> x * x #=> var square = function(x) { return x * x; }
fill = (container, liquid = "Kaffee") ->
"#{container} wird mit #{liquid} gefüllt..."
#=>var fill;
#
#fill = function(container, liquid) {
# if (liquid == null) {
# liquid = "Kaffee";
# }
# return container + " wird mit " + liquid + " gefüllt...";
#};
# "Ranges":
list = [1..5] #=> var list = [1, 2, 3, 4, 5];
# Objekte:
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
#=>race = function() {
# var runners, winner;
# winner = arguments[0], runners = 2 <= arguments.length ? __slice.call(arguments, 1) : [];
# return print(winner, runners);
#};
# Existenz-Operator:
alert "Hab ich's nicht gesagt?" if elvis?
#=> if(typeof elvis !== "undefined" && elvis !== null) { alert("Hab ich's nicht gesagt?"); }
2014-08-21 11:53:07 +00:00
# Listen-Abstraktion:
2014-08-20 17:40:34 +00:00
cubes = (math.cube num for num in list)
2014-08-11 08:02:06 +00:00
#=>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 = ['Brokkoli', 'Spinat', 'Schokolade']
eat food for food in foods when food isnt 'Schokolade'
#=>foods = ['Brokkoli', 'Spinat', 'Schokolade'];
#
#for (_k = 0, _len2 = foods.length; _k < _len2; _k++) {
# food = foods[_k];
# if (food !== 'Schokolade') {
# eat(food);
# }
#}
```
## Weiterführende Links
- [Smooth CoffeeScript ](http://autotelicum.github.io/Smooth-CoffeeScript/ )
- [CoffeeScript Ristretto ](https://leanpub.com/coffeescript-ristretto/read )