aboutsummaryrefslogtreecommitdiff
path: root/files/fr
diff options
context:
space:
mode:
Diffstat (limited to 'files/fr')
-rw-r--r--files/fr/web/javascript/reference/operators/typeof/index.md104
1 files changed, 52 insertions, 52 deletions
diff --git a/files/fr/web/javascript/reference/operators/typeof/index.md b/files/fr/web/javascript/reference/operators/typeof/index.md
index d31c1d7b6b..646f753ef8 100644
--- a/files/fr/web/javascript/reference/operators/typeof/index.md
+++ b/files/fr/web/javascript/reference/operators/typeof/index.md
@@ -1,12 +1,9 @@
---
title: L'opérateur typeof
slug: Web/JavaScript/Reference/Operators/typeof
-tags:
- - JavaScript
- - Operator
- - Reference
translation_of: Web/JavaScript/Reference/Operators/typeof
original_slug: Web/JavaScript/Reference/Opérateurs/L_opérateur_typeof
+browser-compat: javascript.operators.typeof
---
{{jsSidebar("Operators")}}
@@ -16,33 +13,38 @@ L'opérateur **`typeof`** renvoie une chaîne qui indique le type de son opéran
## Syntaxe
-L'opérateur `typeof` est suivi de son opérande :
+L'opérateur `typeof` est suivi de son opérande :
- typeof operande
+```js
+typeof operande
+typeof(operande)
+```
### Paramètre
-`operande` est une expression qui représente la valeur dont on souhaite obtenir le type.
+- `operande`
+ - : Une expression représentant l'objet ou la valeur [primitive](/fr/docs/Glossary/Primitive) dont on souhaite obtenir le type.
## Description
-Le tableau qui suit liste les résultats possibles de l'opérateur `typeof`. Pour plus d'informations sur les types et valeurs primitives en JavaScript, voir la page sur [les types et structures de données JavaScript](/fr/docs/Web/JavaScript/Structures_de_données#Les_valeurs_primitives).
-
-| Type | Résultat |
-| -------------------------------------------------------------------------------- | ------------------------------------------- |
-| indéfini | `"undefined"` |
-| nul | `"object" `(voir ci-après) |
-| booléen | `"boolean"` |
-| nombre | `"number"` |
-| grand entier | `"bigint"` |
-| chaîne de caractère | `"string"` |
-| symbole (nouveauté d'ECMAScript 6 / 2015) | `"symbol"` |
-| objet de l'environnement (fourni par l'environnement dans lequel est utilisé JS) | _Résultat différent selon l'implémentation_ |
-| Objet Function (au sens ECMA-262, un objet qui implémente [[Call]]) | `"function"` |
-| Tout autre objet | `"object"` |
+Le tableau qui suit liste les résultats possibles de l'opérateur `typeof`. Pour plus d'informations sur les types et valeurs primitives en JavaScript, voir la page sur [les types et structures de données JavaScript](/fr/docs/Web/JavaScript/Data_structures).
+
+| Type | Résultat |
+| ------------------------------------------------------------------------------------------------- | -------------------------- |
+| [indéfini](/fr/docs/Glossary/undefined) | `"undefined"` |
+| [nul](/fr/docs/Glossary/Null) | `"object" `(voir ci-après) |
+| [booléen](/fr/docs/Glossary/Boolean) | `"boolean"` |
+| [nombre](/fr/docs/Glossary/Number) | `"number"` |
+| [grand entier (nouveauté d'ECMAScript 2020)](/fr/docs/Glossary/BigInt) | `"bigint"` |
+| [chaîne de caractère](/fr/docs/Glossary/String) | `"string"` |
+| [symbole (nouveauté d'ECMAScript 6 / 2015)](/fr/docs/Glossary/Symbol) | `"symbol"` |
+| [objet Function (au sens ECMA-262, un objet qui implémente [[Call]])](/fr/docs/Glossary/Function) | `"function"` |
+| Tout autre objet | `"object"` |
## Exemples
+### Usage simple
+
```js
// Pour les nombres
typeof 37 === 'number';
@@ -52,6 +54,8 @@ typeof Math.LN2 === 'number';
typeof Infinity === 'number';
typeof NaN === 'number'; // Bien que littéralement ce soit "Not-A-Number"…
typeof Number('1') === 'number'; // Number essaie de convertir l'argument en nombre
+typeof Number('chaussure') === 'number'; // cela vaut également pour les valeurs qui ne peuvent pas être converties
+
// Grand entier
typeof 42n === 'bigint';
@@ -59,28 +63,26 @@ typeof 42n === 'bigint';
// Les chaînes de caractères
typeof "" === 'string';
typeof "bla" === 'string';
+typeof `gabarit de chaîne` === 'string';
typeof "1" === 'string'; // on a ici un nombre écrit sous forme d'une chaîne
typeof (typeof 1) === 'string'; // typeof renvoie toujours une chaîne
typeof String(1) === 'string'; // String convertit n'importe quelle valeur en chaîne
-
// Les booléens
typeof true === 'boolean';
typeof false === 'boolean';
typeof Boolean(1) === 'boolean'; // Boolean convertit n'importe quelle valeur en son équivalent logique
typeof !!(1) === 'boolean'; // deux appels à l'opérateur ! (le NON logique) sont équivalents à Boolean()
-
// Les symboles
typeof Symbol() === 'symbol'
-typeof Symbol('foo') === 'symbol'
+typeof Symbol('toto') === 'symbol'
typeof Symbol.iterator === 'symbol'
-
// Indéfini
typeof undefined === 'undefined';
-typeof blabla === 'undefined'; // pour une variable indéfinie
-
+typeof variableDeclareeMaisIndefinie === 'undefined';
+typeof variableNonDeclaree === 'undefined';
// Les objets
typeof {a:1} === 'object';
@@ -105,9 +107,7 @@ typeof class C {} === 'function';
typeof Math.sin === 'function';
```
-## Informations supplémentaires
-
-### `null`
+### `typeof null`
```js
// Cela est valable depuis les commencements de JavaScript
@@ -116,22 +116,22 @@ typeof null === 'object';
Lors de la première implémentation de JavaScript, les valeurs JavaScript étaient représentées avec une étiquette de type et une valeur. Pour les objets, l'étiquette de type était 0. `null` était représenté par la valeur NULL (0x00 pour la plupart des plates-formes). Par conséquent, l'étiquette de type de `null` valait 0, d'où le comportement de `typeof` ([source](https://www.2ality.com/2013/10/typeof-null.html)).
-Un correctif fut proposé pour ECMAScript mais il fut [refusé](https://web.archive.org/web/20160331031419/http://wiki.ecmascript.org:80/doku.php?id=harmony:typeof_null). Avec cette version, on aurait eu `typeof null === 'null'`.
+Un correctif fut proposé pour ECMAScript, mais il fut [refusé](https://web.archive.org/web/20160331031419/http://wiki.ecmascript.org:80/doku.php?id=harmony:typeof_null). Avec cette version, on aurait eu `typeof null === 'null'`.
### Utiliser l'opérateur `new`
```js
// Tous les constructeurs doivent être employés
// avec le mot-clé "new"
-var maChaine = new String("toto");
-var monNombre = new Number(100);
+let maChaine = new String("toto");
+let monNombre = new Number(100);
typeof maChaine; // renverra "object"
typeof monNombre; // renverra "object"
// En revanche avec le constructeur Function,
// on aura :
-var maFonction = new Function();
+let maFonction = new Function();
typeof maFonction; // renverra "function"
```
@@ -142,10 +142,10 @@ typeof maFonction; // renverra "function"
// déterminer le type de données d'une expression
// complète
-var maDonnee = 99;
+let maDonnee = 99;
-typeof maDonnee + 'Toto'; // renverra 'number Toto'
-typeof (maDonnee + 'Toto'); // renverra 'string'
+typeof maDonnee + ' Toto'; // renverra 'number Toto'
+typeof (maDonnee + ' Toto'); // renverra 'string'
```
### Expressions rationnelles
@@ -157,11 +157,11 @@ typeof /s/ === 'function'; // Chrome 1 à 12 : Non conforme à ECMAScript 5.1
typeof /s/ === 'object'; // À partir de Firefox 5 : Conforme à ECMAScript 5.1
```
-### Zone morte temporaire (_Temporal Dead Zone_ / TDZ)
+### Erreurs et zone morte temporaire (_Temporal Dead Zone_ / TDZ)
Avant ECMAScript 2015 (ES6), `typeof` retournait toujours une chaîne de caractères, quel que soit l'opérande utilisé. On ne pouvait pas avoir d'erreur en utilisant `typeof`.
-Avec l'apparition des opérateurs [`let`](/fr/docs/Web/JavaScript/Reference/Instructions/let) et [`const`](/fr/docs/Web/JavaScript/Reference/Instructions/const), si on utilise `typeof` sur des variables déclarées avec ces opérateurs (ou avec une classe) avant leur déclaration, cela déclenchera une erreur {{jsxref("ReferenceError")}}. Si on utilise `typeof` sur une variable déclarée avec `var` avant la déclaration, cela renverra `undefined`. Les variables déclarées avec `let` et `const` sont en fait placées dans une *[zone morte temporaire ](</fr/docs/Web/JavaScript/Reference/Instructions/let#Zone_morte_temporaire_(Temporal_Dead_Zone_TDZ)_et_les_erreurs_liées_à_let>)*entre le début du bloc et leur initialisation et dans cette zone, tout accès à la variable produit une erreur.
+Avec l'apparition des opérateurs [`let`](/fr/docs/Web/JavaScript/Reference/Statements/let) et [`const`](/fr/docs/Web/JavaScript/Reference/Statements/const), si on utilise `typeof` sur des variables déclarées avec ces opérateurs (ou avec une classe) avant leur déclaration, cela déclenchera une erreur [`ReferenceError`](/fr/docs/Web/JavaScript/Reference/Global_Objects/ReferenceError). Si on utilise `typeof` sur une variable déclarée avec `var` avant la déclaration, cela renverra `undefined`. Les variables déclarées avec `let` et `const` sont en fait placées dans une *[zone morte temporaire ](/fr/docs/Web/JavaScript/Reference/Statements/let)*entre le début du bloc et leur initialisation et dans cette zone, tout accès à la variable produit une erreur.
```js
typeof variableGlobaleNonDeclaree === "undefined";
@@ -178,27 +178,20 @@ class maClasse{};
### Exceptions
-Tous les navigateurs actuels exposent un objet non-standard {{domxref("document.all")}} dont le type est `"undefined"`.
+Tous les navigateurs actuels exposent un objet non-standard [`document.all`](/fr/docs/Web/API/document/all) dont le type est `undefined`.
```js
typeof document.all === "undefined";
```
-Bien que la spécification requière que les objets exostiques aient des types différents, ces types doivent être des chaînes différentes des chaînes existantes pour les objets standards. À ce titre, le type de `document.all` représente une violation « volontaire » du standard ECMAScript original.
+Bien que la spécification requière que les objets exotiques aient des types différents, ces types doivent être des chaînes différentes des chaînes existantes pour les objets standards. À ce titre, le type de `document.all` représente une violation « volontaire » du standard ECMAScript original.
## Spécifications
-| Spécification | État | Commentaires |
-| -------------------------------------------------------------------------------------------- | ---------------------------- | ----------------------------------------------------- |
-| {{SpecName('ESDraft', '#sec-typeof-operator', 'Opérateur typeof')}} | {{Spec2('ESDraft')}} | |
-| {{SpecName('ES6', '#sec-typeof-operator', 'Opérateur typeof')}} | {{Spec2('ES6')}} | |
-| {{SpecName('ES5.1', '#sec-11.4.3', 'Opérateur typeof')}} | {{Spec2('ES5.1')}} | |
-| {{SpecName('ES3', '#sec-11.4.3', 'Opérateur typeof')}} | {{Spec2('ES3')}} | |
-| {{SpecName('ES1', '#sec-11.4.3', 'Opérateur typeof')}} | {{Spec2('ES1')}} | Définition initiale, implémentée avec JavaScript 1.1. |
-
+{{Specifications}}
## Compatibilité des navigateurs
-{{Compat("javascript.operators.typeof")}}
+{{Compat}}
## Notes spécifiques à IE
@@ -208,8 +201,15 @@ Pour les versions 6, 7 et 8 d'Internet Explorer, les objets de l'environnement h
typeof alert === 'object'
```
+Certaines propriétés non-standard d'IE renvoient d'autres valeurs ([tc39/ecma262#1440
+(commentaire)](https://github.com/tc39/ecma262/issues/1440#issuecomment-461963872)):
+
+```js
+typeof window.external.AddSearchProvider === "unknown";
+typeof window.external.IsSearchProviderInstalled === "unknown";
+```
+
## Voir aussi
-- L'opérateur {{jsxref("Opérateurs/instanceof","instanceof")}}
-- [Discussion es-discuss sur l'évolution de `typeof` avec ECMAScript 2015 et `let`](http://es-discourse.com/t/why-typeof-is-no-longer-safe/15)
+- L'opérateur [`instanceof`](/fr/docs/Web/JavaScript/Reference/Operators/instanceof)
- [À propos du non-respect volontaire du standard avec le type de `document.all`](https://github.com/tc39/ecma262/issues/668)