learnxinyminutes-docs/fr/livescript.md

353 lines
11 KiB
Markdown
Raw Normal View History

2015-07-08 08:54:37 +00:00
---
contributors:
- ["Christina Whyte", "http://github.com/kurisuwhyte/"]
translators:
- ["Morgan Bohn", "https://github.com/dotmobo"]
2015-07-08 08:54:37 +00:00
---
LiveScript est un langage qui compile en JavaScript. Il a un rapport direct
avec JavaScript, et vous permet d'écrire du JavaScript plus simplement, plus
efficacement et sans répétitivité. LiveScript ajoute non seulement des
fonctionnalités pour écrire du code fonctionnel, mais possède aussi nombre
d'améliorations pour la programmation orientée objet et la programmation
impérative.
2015-07-08 08:54:37 +00:00
LiveScript est un descendant direct de [Coco][], indirect de [CoffeeScript][],
avec lequel il a beaucoup plus de compatibilité.
2015-07-08 08:54:37 +00:00
[Coco]: http://satyr.github.io/coco/
[CoffeeScript]: http://coffeescript.org/
2024-04-08 14:07:03 +00:00
```livescript
2015-07-08 08:54:37 +00:00
# Comme son cousin CoffeeScript, LiveScript utilise le symbole dièse pour les
# commentaires sur une ligne.
/*
Les commentaires sur plusieurs lignes utilisent la syntaxe du C. Utilisez-les
si vous voulez préserver les commentaires dans la sortie JavaScript.
*/
2024-04-08 14:07:03 +00:00
2015-07-08 08:54:37 +00:00
# LiveScript utilise l'indentation pour délimiter les blocs de code plutôt que
2015-07-08 11:41:15 +00:00
# les accolades, et les espaces pour appliquer les fonctions (bien que les
# parenthèses soient utilisables).
2015-07-08 08:54:37 +00:00
########################################################################
## 1. Valeurs basiques
########################################################################
# Les valeurs non définies sont représentées par le mot clé `void` à la place de
# `undefined`
void # comme `undefined` mais plus sûr (ne peut pas être redéfini)
# Une valeur non valide est représentée par Null.
null
2015-07-08 11:41:15 +00:00
# Les booléens s'utilisent de la façon suivante:
2015-07-08 08:54:37 +00:00
true
false
# Et il existe divers alias les représentant également:
on; off
yes; no
# Puis viennent les nombres entiers et décimaux.
10
0.4 # Notez que le `0` est requis
# Dans un souci de lisibilité, vous pouvez utiliser les tirets bas et les
# suffixes sur les nombres. Il seront ignorés à la compilation.
12_344km
# Les chaînes sont des séquences immutables de caractères, comme en JS:
"Christina" # Les apostrophes fonctionnent également!
"""Multi-line
strings
are
okay
too."""
# De temps à autre, vous voulez encoder un mot clé; la notation en backslash
# rend cela facile:
\keyword # => 'keyword'
# Les tableaux sont des collections ordonnées de valeurs.
fruits =
* \apple
* \orange
* \pear
# Il peuvent être écrits de manière plus consises à l'aide des crochets:
fruits = [ \apple, \orange, \pear ]
# Vous pouvez également utiliser la syntaxe suivante, à l'aide d'espaces, pour
# créer votre liste de valeurs:
fruits = <[ apple orange pear ]>
# Vous pouvez récupérer une entrée à l'aide de son index:
fruits[0] # => "apple"
# Les objets sont une collection non ordonnées de paires clé/valeur, et
2024-12-19 00:58:08 +00:00
# d'autres choses (que nous verrons plus tard).
2015-07-08 08:54:37 +00:00
person =
name: "Christina"
likes:
* "kittens"
* "and other cute stuff"
# A nouveau, vous pouvez utiliser une expression plus consise à l'aide des
2024-12-19 00:58:08 +00:00
# accolades:
2015-07-08 08:54:37 +00:00
person = {name: "Christina", likes: ["kittens", "and other cute stuff"]}
# Vous pouvez récupérer une entrée via sa clé:
person.name # => "Christina"
person["name"] # => "Christina"
# Les expressions régulières utilisent la même syntaxe que JavaScript:
trailing-space = /\s$/ # les mots-composés deviennent motscomposés
# A l'exception que vous pouvez pouvez utiliser des expressions sur plusieurs
2024-12-19 00:58:08 +00:00
# lignes!
2015-07-08 08:54:37 +00:00
# (les commentaires et les espaces seront ignorés)
funRE = //
function\s+(.+) # nom
\s* \((.*)\) \s* # arguments
{ (.*) } # corps
//
########################################################################
## 2. Les opérations basiques
########################################################################
# Les opérateurs arithmétiques sont les mêmes que pour JavaScript:
1 + 2 # => 3
2 - 1 # => 1
2 * 3 # => 6
4 / 2 # => 2
3 % 2 # => 1
# Les comparaisons sont presque identiques, à l'exception que `==` équivaut au
2024-12-19 00:58:08 +00:00
# `===` de JS, là où le `==` de JS est `~=` en LiveScript, et `===` active la
# comparaison d'objets et de tableaux, ainsi que les comparaisons strictes
# (sans conversion de type)
2015-07-08 08:54:37 +00:00
2 == 2 # => true
2 == "2" # => false
2 ~= "2" # => true
2 === "2" # => false
[1,2,3] == [1,2,3] # => false
[1,2,3] === [1,2,3] # => true
+0 == -0 # => true
+0 === -0 # => false
# Les opérateurs suivants sont également disponibles: <, <=, > et >=
# Les valeurs logiques peuvent être combinéees grâce aux opérateurs logiques
# `or`, `and` et `not`
true and false # => false
false or true # => true
not false # => true
# Les collections ont également des opérateurs additionnels
[1, 2] ++ [3, 4] # => [1, 2, 3, 4]
'a' in <[ a b c ]> # => true
'name' of { name: 'Chris' } # => true
########################################################################
## 3. Fonctions
########################################################################
# Puisque LiveScript est fonctionnel, vous vous attendez à une bonne prise en
2024-12-19 00:58:08 +00:00
# charge des fonctions. En LiveScript, il est encore plus évident que les
# fonctions sont de premier ordre:
2015-07-08 08:54:37 +00:00
add = (left, right) -> left + right
add 1, 2 # => 3
2015-07-08 11:41:15 +00:00
# Les fonctions qui ne prennent pas d'arguments peuvent être appelées avec un
# point d'exclamation!
2015-07-08 08:54:37 +00:00
two = -> 2
two!
# LiveScript utilise l'environnement de la fonction, comme JavaScript.
# A l'inverse de JavaScript, le `=` fonctionne comme un opérateur de
2024-12-19 00:58:08 +00:00
# déclaration, et il déclarera toujours la variable située à gauche (sauf si
2015-07-08 11:41:15 +00:00
# la variable a été déclarée dans l'environnement parent).
2015-07-08 08:54:37 +00:00
# L'opérateur `:=` est disponible pour réutiliser un nom provenant de
# l'environnement parent.
2015-07-08 11:41:15 +00:00
# Vous pouvez extraire les arguments d'une fonction pour récupérer
2024-12-19 00:58:08 +00:00
# rapidement les valeurs qui vous intéressent dans une structure de données
2015-07-08 08:54:37 +00:00
# complexe:
tail = ([head, ...rest]) -> rest
tail [1, 2, 3] # => [2, 3]
# Vous pouvez également transformer les arguments en utilisant les opérateurs
2024-12-19 00:58:08 +00:00
# binaires et unaires. Définir des arguments par défaut est aussi possible.
2015-07-08 08:54:37 +00:00
foo = (a = 1, b = 2) -> a + b
foo! # => 3
# You pouvez utiliser cela pour cloner un argument en particulier pour éviter
2024-12-19 00:58:08 +00:00
# les effets secondaires. Par exemple:
2015-07-08 08:54:37 +00:00
copy = (^^target, source) ->
for k,v of source => target[k] = v
target
a = { a: 1 }
copy a, { b: 2 } # => { a: 1, b: 2 }
a # => { a: 1 }
2015-07-08 11:41:15 +00:00
# Une fonction peut être curryfiée en utilisant une longue flèche à la place
2015-07-08 08:54:37 +00:00
# d'une courte:
add = (left, right) --> left + right
add1 = add 1
add1 2 # => 3
# Les fonctions ont un argument `it` implicite si vous n'en déclarez pas:
identity = -> it
identity 1 # => 1
# Les opérateurs ne sont pas des fonctions en LiveScript, mais vous pouvez
2024-12-19 00:58:08 +00:00
# facilement les transformer en fonction:
2015-07-08 08:54:37 +00:00
divide-by-two = (/ 2)
2015-07-08 11:41:15 +00:00
[2, 4, 8, 16].map(divide-by-two).reduce (+)
2015-07-08 08:54:37 +00:00
# Comme dans tout bon langage fonctionnel, vous pouvez créer des fonctions
2024-12-19 00:58:08 +00:00
# composées d'autres fonctions:
2015-07-08 08:54:37 +00:00
double-minus-one = (- 1) . (* 2)
# En plus de la formule mathématique `f . g`, vous avez les opérateurs `>>`
2015-07-08 11:41:15 +00:00
# et `<<`, qui décrivent l'ordre d'application des fonctions composées.
2015-07-08 08:54:37 +00:00
double-minus-one = (* 2) >> (- 1)
double-minus-one = (- 1) << (* 2)
# Pour appliquer une valeur à une fonction, vous pouvez utiliser les opérateurs
2024-12-19 00:58:08 +00:00
# `|>` et `<|`:
2015-07-08 08:54:37 +00:00
map = (f, xs) --> xs.map f
[1 2 3] |> map (* 2) # => [2 4 6]
2015-07-08 11:43:17 +00:00
# La version sans pipe correspond à:
2015-07-08 11:41:15 +00:00
((map (* 2)) [1, 2, 3])
2015-07-08 08:54:37 +00:00
# You pouvez aussi choisir où vous voulez que la valeur soit placée, en
# marquant la position avec un tiret bas (_):
reduce = (f, xs, initial) --> xs.reduce f, initial
[1 2 3] |> reduce (+), _, 0 # => 6
2024-12-19 00:58:08 +00:00
# Le tiret bas est également utilisé pour l'application partielle,
# que vous pouvez utiliser pour toute fonction:
2015-07-08 08:54:37 +00:00
div = (left, right) -> left / right
div-by-two = div _, 2
div-by-two 4 # => 2
2015-07-08 11:41:15 +00:00
# Pour conclure, LiveScript vous permet d'utiliser les fonctions de rappel.
2024-12-19 00:58:08 +00:00
# (mais vous devriez essayer des approches plus fonctionnelles, comme
2015-07-08 11:41:15 +00:00
# Promises).
# Un fonction de rappel est une fonction qui est passée en argument à une autre
# fonction:
2015-07-08 08:54:37 +00:00
readFile = (name, f) -> f name
a <- readFile 'foo'
b <- readFile 'bar'
console.log a + b
# Equivalent à:
readFile 'foo', (a) -> readFile 'bar', (b) -> console.log a + b
########################################################################
## 4. Conditionnalités
########################################################################
# Vous pouvez faire de la conditionnalité à l'aide de l'expression `if...else`:
x = if n > 0 then \positive else \negative
# A la place de `then`, vous pouvez utiliser `=>`
x = if n > 0 => \positive
else \negative
# Pour les conditions complexes, il vaut mieux utiliser l'expresssion `switch`:
y = {}
x = switch
| (typeof y) is \number => \number
| (typeof y) is \string => \string
| 'length' of y => \array
| otherwise => \object # `otherwise` et `_` correspondent.
# Le corps des fonctions, les déclarations et les assignements disposent d'un
2024-12-19 00:58:08 +00:00
# `switch` implicite, donc vous n'avez pas besoin de le réécrire:
2015-07-08 08:54:37 +00:00
take = (n, [x, ...xs]) -->
2015-07-08 11:41:15 +00:00
| n == 0 => []
| _ => [x] ++ take (n - 1), xs
2015-07-08 08:54:37 +00:00
########################################################################
## 5. Compréhensions
########################################################################
# Comme en python, vous allez pouvoir utiliser les listes en compréhension,
2024-12-19 00:58:08 +00:00
# ce qui permet de générer rapidement et de manière élégante une liste de
# valeurs:
2015-07-08 08:54:37 +00:00
oneToTwenty = [1 to 20]
evens = [x for x in oneToTwenty when x % 2 == 0]
# `when` et `unless` peuvent être utilisés comme des filtres.
2024-12-19 00:58:08 +00:00
# Cette technique fonctionne sur les objets de la même manière. Vous allez
2015-07-08 11:41:15 +00:00
# pouvoir générer l'ensemble de paires clé/valeur via la syntaxe suivante:
2015-07-08 08:54:37 +00:00
copy = { [k, v] for k, v of source }
########################################################################
## 4. Programmation orientée objet
########################################################################
# Bien que LiveScript soit un langage fonctionnel, il dispose d'intéressants
2024-12-19 00:58:08 +00:00
# outils pour la programmation objet. La syntaxe de déclaration d'une classe
# est héritée de CoffeeScript:
2015-07-08 08:54:37 +00:00
class Animal
(@name, kind) ->
@kind = kind
action: (what) -> "*#{@name} (a #{@kind}) #{what}*"
class Cat extends Animal
(@name) -> super @name, 'cat'
purr: -> @action 'purrs'
kitten = new Cat 'Mei'
kitten.purr! # => "*Mei (a cat) purrs*"
# En plus de l'héritage classique, vous pouvez utiliser autant de mixins
2024-12-19 00:58:08 +00:00
# que vous voulez pour votre classe. Les mixins sont juste des objets:
2015-07-08 08:54:37 +00:00
Huggable =
hug: -> @action 'is hugged'
class SnugglyCat extends Cat implements Huggable
kitten = new SnugglyCat 'Purr'
kitten.hug! # => "*Mei (a cat) is hugged*"
```
## Lectures complémentaires
Il y a beaucoup plus de choses à dire sur LiveScript, mais ce guide devrait
suffire pour démarrer l'écriture de petites fonctionnalités.
Le [site officiel](http://livescript.net/) dispose de beaucoup d'information,
ainsi que d'un compilateur en ligne vous permettant de tester le langage!
Jetez également un coup d'oeil à [prelude.ls](http://gkz.github.io/prelude-ls/),
et consultez le channel `#livescript` sur le réseau Freenode.