JavaScript : comment appliquer une méthode à un numérique littéral
Par Bovino
Le 08/04/2015, par Bovino, Rédacteur
En JavaScript, il existe deux méthodes pour appeler une méthode ou récupérer un propriété d'un objet : la syntaxe à crochets et la syntaxe pointée, la plus courante.
Par exemple, pour récupérer la taille d'une chaine ou d'un tableau, on utilisera
Avec la notation à crochets, la syntaxe deviendra
Et cela fonctionne aussi bien avec les méthodes
Tout cela fonctionne parfaitement avec tous les objets possibles.
Tous ? Vraiment ?
En fait, pas vraiment. Un problème survient avec les littéraux numériques entiers.
En effet, si l'on fait
Mais
c'est le drame... En effet, dans le cas des littéraux numériques, le point sert à séparer la partie entière de la partie décimale et dans le dernier exemple, toFixed(2) n'est pas une partie décimale valide.
L'astuce va être alors de mettre deux points à la suite et le tour est joué :
Bien entendu, c'est une question que vous ne vous êtes jamais posée parce qu'en toute franchise, les cas où cela peut servir sont tellement rares qu'on se demande même s'il en existe !
Mais au moins, ça vous permettra de briller lors des dîners entre JavaScripteurs.
Par exemple, pour récupérer la taille d'une chaine ou d'un tableau, on utilisera
Code javascript : |
1 2 | console.log('foo'.length); // 3 console.log([1,2,3].length); // 3 |
Avec la notation à crochets, la syntaxe deviendra
Code javascript : |
1 2 | console.log('foo'['length']); // 3 console.log([1,2,3]['length']); // 3 |
Et cela fonctionne aussi bien avec les méthodes
Code javascript : |
1 2 | console.log('foo'['replace']('foo', 'bar')); // bar console.log([1,2,3]['push'](4)); // 4 |
Tout cela fonctionne parfaitement avec tous les objets possibles.
Tous ? Vraiment ?
En fait, pas vraiment. Un problème survient avec les littéraux numériques entiers.
En effet, si l'on fait
Code javascript : |
console.log(12.5.toFixed(2)); // 12.50
Code javascript : |
console.log(12.toFixed(2)); // SyntaxError: identifier starts immediately after numeric literal
L'astuce va être alors de mettre deux points à la suite et le tour est joué :
Code javascript : |
console.log(12..toFixed(2)); // 12.50
Bien entendu, c'est une question que vous ne vous êtes jamais posée parce qu'en toute franchise, les cas où cela peut servir sont tellement rares qu'on se demande même s'il en existe !
Mais au moins, ça vous permettra de briller lors des dîners entre JavaScripteurs.