Programmation JavaScript/Mots réservés
Cet article va passer en revue les mots réservés et constantes prédéfinies de JavaScript.
La norme ECMA 262, définit les mots réservés de JavaScript en deux catégories :
- les mots réservés (break else new var case finally return void catch for switch while continue function this with default if throw delete in try do instanceof typeof)
- les futurs mots réservés (abstract enum int short boolean export interface static byte extends long super char final native synchronized class float package throws const goto private transient debugger implements protected volatile double import public).
On ne doit pas utiliser un mot réservé comme identificateur. Cela provoque une erreur. Mais comme le langage différencie les majuscules et minuscules, il est possible de mettre en majuscule une lettre pour rendre l'identificateur utilisable.
On peut, avec la plupart des navigateurs utiliser un futur mot réservé comme identificateur, mais cela est déconseillé, car le programme ne fonctionnera probablement plus à l'apparition d'une version future de JavaScript.
Voici une description sommaire des mots réservés[1] :
Déclarations
modifiervar
modifierDéclaration d'une variable locale, avec ou sans affectation. À placer en début d'instruction.
var ma_variable;
var ma_variable = "Je suis affecté";
Une variable locale est détruite automatiquement à la fin de la fonction où elle a été créée (sauf dans le cas des closures). Seul le code écrit dans cette fonction peut y accéder, et dans ce code, la variable est prioritaire sur tout autre identifiant homonyme. En revanche, elle ne peut être détruite par l'opérateur delete.
Voir la section sur rehaussement des déclarations.
const
modifierDéclaration d'une constante locale[2].
let
modifierComme "var" mais restreint la portée au bloc, comme si ce bloc était situé dans une autre fonction. Exemple :
var a = 1;
var b = 2;
{
var a = 11;
let b = 22;
}
console.log(a); // 11
console.log(b); // 2
function
modifierDéclaration d'une fonction utilisateur. C'est aussi un opérateur.
function ma_fonction()
{
alert("Je suis exécuté dans ma_fonction");
}
void
modifiervoid est une déclaration placée obligatoirement en début d'instruction. void ne fait rien, ne retourne rien, et n'est utile que dans un seul contexte : les pseudo-URL javascript:
. En effet, si l'instruction qui compose cet URL retourne une valeur, cette valeur remplace le contenu de la page, ce qui est souvent indésirable. On place alors la déclaration void pour que l'instruction n'ait aucune valeur.
<a href="javascript:void(maFonction())">...</a>
with
modifierPermet de simplifier la référence aux propriétés et méthodes des objets en précédant un bloc d'instruction dans lequel un objet devient implicite. La déclaration with rajoute en fait un niveau tout en haut de la pile de scopes.
with(navigator)
{
alert(appName + " " + appVersion);
}
est équivalent à
alert(navigator.appName + " " +navigator.appVersion);
Structures de contrôle
modifierreturn
modifierEmployé dans une fonction, provoque le retour au programme appelant avec renvoi facultatif d'un résultat.
function ma_fonction(aparam)
{
s = "";
if (aparam == "")
return; // Sortie sans renvoyer de résultat
else
s = "Le résultat";
return s; // Renvoie le contenu de s
}
if
modifierPermet de définir l'exécution conditionnelle d'instructions ou d'un bloc d'instructions. Peut-être utilisé conjointement à else.
a = 5;
if (a==5)
alert("la condition est remplie");
else
modifierUtilisé conjointement à if, permet d'exécuter des instructions alternativement au résultat de la condition spécifiée par if.
a = 5
if (a==5)
alert("a est égal à 5");
else
alert("a est différent de 5");
switch
modifierUtilisé conjointement à case, permet d'implanter un sélecteur de cas.
function test(condition)
{
switch(condition)
{
case "1":
alert("condition='1'");
break;
case "3":
alert("condition='3'");
break;
case "5":
alert("condition='5'");
break;
}
}
case
modifierUtilisé à l'intérieur d'un bloc switch, constitue un des choix du sélecteur.
break
modifierUtilisé à l'intérieur d'un bloc switch, permet de sortir du sélecteur sans procéder tests suivants. Utilisé à l'intérieur d'une boucle telle un bloc switch, permet de quitter la boucle immédiatement.
default
modifierUtilisé à l'intérieur d'un bloc switch, constitue l'option par défaut du sélecteur.
for
modifierIntroduit une boucle itérative.
for (i=0;i<5;i++)
{
alert(i);
}
For each :
var array = [1, 2, 3];
for (line in array)
{
alert(line);
}
En tableau associatif :
var array = { "a" : 1, "b" : 2, "c": 3 };
for (const line in array)
{
alert('Clé : ' + line + ', valeur : ' + array[line]);
}
NB : voir aussi la méthode Array.prototype.forEach()[3].
do
modifierIntroduit une boucle itérative conditionnelle avec test effectué à chaque tour par "while" :
i=0
do
{
i++
alert(i); // Affichera 1, puis 2, puis 3, puis 4, puis 5
}
while(i<5);
while
modifierIntroduit une boucle itérative conditionnelle:
i=0
while(i<5)
{
i++; // Incrémenter i
alert(i); // Affiche 1, puis 2, puis 3, puis 4, puis 5
}
continue
modifierUtilisé dans une boucle "for", "while" et "do", permet de sauter un tour.
for (i=-2;i<=2;i++)
{
if (i==0) continue; // Si i == 0, on passe directement à 1
alert(5/i); // On évite ainsi la division par zéro.
}
Gestions des erreurs
modifierthrow
modifierProvoque une erreur personnalisée.
throw new Error("votre erreur");// a le même effet visuel que alert("votre erreur");
try ... catch ... finally
modifierÉvalue un bloc (try) en capturant les erreurs, tente de les gérer (catch) si elles se produisent, et quoiqu'il arrive, évalue un dernier bloc (finally).
Opérateurs
modifierin
modifierOpérateur qui détermine l'appartenance à un objet. Dans une boucle for... in, permet de répéter des instructions pour chaque propriété d'un objet.
new
modifierOpérateur qui permet l'instanciation d'un objet.
var mon_tableau = new Array();
instanceof
modifierCet opérateur permet de tester si une valeur est une instance d'un objet :
t = new Array();
alert(t instanceof Array); // Affiche true
alert(t instanceof Date); // Affiche false
typeof
modifierCet opérateur renvoie le type de la variable placée à droite.
Les valeurs renvoyées par typeof correspondent aux types de variables JavaScript, soit :
boolean string number function object undefined.
delete
modifierCet opérateur permet de supprimer une propriété.
Valeurs spéciales
modifierthis
modifierDans le constructeur ou une méthode d'un objet, c'est une référence à l'objet. Hors de ce contexte, this référence l'objet global window.
true
modifierValeur booléenne "vrai".
if (true)
{
alert("Je m'affiche toujours");
}
false
modifierValeur booléenne "faux".
if (ma_bool == false)
alert("C'est pas vrai...")
null
modifierValeur de type "object" qui ne référence rien.
undefined
modifierC'est la valeur de toutes les variables inexistantes ou supprimées.
Nouveaux mots réservés
modifierawait
modifierclass
modifierconst
modifierdebugger
modifierexport
modifierextends
modifierimport
modifierstatic
modifieryield
modifierFuturs mots réservés
modifierLes versions futures de JavaScript intégreront peut-être un ou plusieurs mots réservés parmi la liste suivante. Il est donc officiellement déconseillé de les employer comme identificateurs dans les programmes actuels, sous peine de risquer un comportement bizarre dans le futur[4].
abstract
boolean
byte
char
double
enum
final
float
goto
implements
int
interface
long
native
package
private
protected
public
short
super
enum, implements, interface, private, static
.Références
modifier- ↑ https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Lexical_grammar#keywords
- ↑ https://developer.mozilla.org/fr/docs/Web/JavaScript/Reference/Instructions/const
- ↑ https://developer.mozilla.org/fr/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach
- ↑ https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Lexical_grammar#future_reserved_words