aboutsummaryrefslogtreecommitdiff
path: root/files/fr/web/javascript/reference/global_objects/array/@@species/index.md
blob: 1a4970e0f7f6b8096132b6db67499b1eee9f0ad8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
---
title: get Array[@@species]
slug: Web/JavaScript/Reference/Global_Objects/Array/@@species
tags:
  - Array
  - JavaScript
  - Méthode
  - Prototype
  - Reference
translation_of: Web/JavaScript/Reference/Global_Objects/Array/@@species
original_slug: Web/JavaScript/Reference/Objets_globaux/Array/@@species
---
{{JSRef}}

La propriété d'accesseur **`Array[@@species]`** renvoie le constructeur `Array`.

## Syntaxe

    Array[Symbol.species]

### Valeur de retour

Le constructeur {{jsxref("Array")}}.

## Description

L'accesseur `species` renvoie le constructeur par défaut pour les objets `Array`. Les constructeurs des sous-classes peuvent le surcharger afin de modifier l'affectation du constructeur.

## Exemples

La propriété renvoie le constructeur par défaut, dans le cas des objets `Array`, c'est le constructeur `Array` :

```js
Array[Symbol.species]; // function Array()
```

Pour un objet dérivé, la valeur de `species` pour une classe `MonArray` sera le constructeur de cette classe. Vous pouvez surcharger ce comportement afin de renvoyer le constructeur `Array` :

```js
class MonArray extends Array {
  // On surcharge le symbole species
  // pour renvoyer le constructeur Array parent
  static get [Symbol.species]() { return Array; }
}
```

## Spécifications

| Spécification                                                                                            | État                         | Commentaires         |
| -------------------------------------------------------------------------------------------------------- | ---------------------------- | -------------------- |
| {{SpecName('ES6', '#sec-get-array-@@species', 'get Array [ @@species ]')}}     | {{Spec2('ES6')}}         | Définition initiale. |
| {{SpecName('ESDraft', '#sec-get-array-@@species', 'get Array [ @@species ]')}} | {{Spec2('ESDraft')}} |                      |

## Compatibilité des navigateurs

{{Compat("javascript.builtins.Array.@@species")}}

## Voir aussi

- {{jsxref("Array")}}
- {{jsxref("Symbol.species")}}