2014-10-10 19:35:22 +00:00
---
2024-10-20 21:46:35 +00:00
language: CoffeeScript
2014-10-10 19:35:22 +00:00
contributors:
- ["Tenor Biel", "http://github.com/L8D"]
- ["Xavier Yao", "http://github.com/xavieryao"]
2014-10-10 21:56:33 +00:00
translators:
2014-10-10 19:35:22 +00:00
- ["asaskevich", "http://github.com/asaskevich"]
2014-10-10 21:18:04 +00:00
filename: learncoffee-ru.coffee
2014-10-10 19:35:22 +00:00
---
2014-10-12 08:03:06 +00:00
CoffeeScript - это небольшой язык, который компилируется один-в-один в эквивалентный код на языке JavaScript, а потому он не интерпретируется во время исполнения JavaScript кода.
2014-10-10 19:35:22 +00:00
Ключевой особенностью CoffeeScript является то, что он пытается создать читабельный, качественно оформленный и плавный JavaScript код, прекрасно работающий в любой среде JavaScript.
2014-10-12 08:03:06 +00:00
Также загляните на официальный сайт [языка ](http://coffeescript.org/ ), где можно найти весьма полное учебное пособие по CoffeeScript.
2014-10-10 19:35:22 +00:00
```coffeescript
# CoffeeScript - язык хипстеров.
2014-10-12 08:03:06 +00:00
# Язык использует самое модное из множества современных языков.
2014-10-10 19:35:22 +00:00
# Эти комментарии по стилю похожи на комментарии Ruby или Python, они используют "решетку" в качестве знака комментария.
###
Блоки комментариев выделяются тремя символами "решетки", в результирующем JavaScript коде они будут преобразованы в '/ * и '* /'.
Перед тем, как идти далее, Вам нужно понимать семантику JavaScript.
###
# Присвоение:
number = 42 #=> var number = 42;
opposite = true #=> var opposite = true;
# Условия:
number = -42 if opposite #=> if(opposite) { number = -42; }
# Функции:
square = (x) -> x * x #=> var square = function(x) { return x * x; }
fill = (container, liquid = "coffee") ->
"Заполняем #{container} жидкостью #{liquid}..."
#=>var fill;
#
#fill = function(container, liquid) {
# if (liquid == null) {
# liquid = "coffee";
# }
# return "Заполняем " + container + " жидкостью " + liquid + "...";
#};
# Списки и диапазоны:
list = [1..5] #=> var list = [1, 2, 3, 4, 5];
# Объекты:
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); }
#}
2014-10-12 08:11:40 +00:00
# Многоточия:
2014-10-10 19:35:22 +00:00
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);
#};
# Проверка на существование объекта:
2014-10-12 08:03:06 +00:00
alert "Так и знал!" if elvis?
#=> if(typeof elvis !== "undefined" && elvis !== null) { alert("Так и знал!"); }
2014-10-10 19:35:22 +00:00
2014-10-12 08:11:40 +00:00
# Итерации по массивам:
2014-10-10 19:35:22 +00: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);
# }
#}
```
## Н а почитать
- [Smooth CoffeeScript ](http://autotelicum.github.io/Smooth-CoffeeScript/ )
- [CoffeeScript Ristretto ](https://leanpub.com/coffeescript-ristretto/read )
- [CoffeeScript на русском ](http://cidocs.ru/coffeescript/ )