Maison > interface Web > js tutoriel > Comment Array.prototype.slice.call(arguments) transforme-t-il les arguments en tableau ?

Comment Array.prototype.slice.call(arguments) transforme-t-il les arguments en tableau ?

Linda Hamilton
Libérer: 2024-10-21 22:02:02
original
1068 Les gens l'ont consulté

How Does Array.prototype.slice.call(arguments) Transform Arguments into an Array?

Plongée dans le fonctionnement interne de Array.prototype.slice.call(arguments)

Comprendre le comportement de Array.prototype.slice. call(arguments) exige une exploration approfondie au-delà de son utilisation au niveau de la surface consistant à convertir des arguments en un véritable tableau.

Normalement, lorsque slice() est directement invoqué sur un tableau, il parcourt les éléments de celui-ci. tableau. Cependant, l'utilisation de .call() et .apply() offre une opportunité unique de définir manuellement la valeur de this dans une fonction.

Dans le cas de Array.prototype.slice.call(arguments), un tableau -un objet de type , possédant des propriétés numériques .length et indexées, est remplacé par ceci. Cette substitution trompe slice() en lui faisant supposer qu'il s'agit d'un véritable tableau, facilitant ainsi son fonctionnement normal.

Considérez l'exemple suivant où un objet simple, sans propriétés de tableau inhérentes, est défini comme ceci à l'aide de .call() :

var my_object = {
    '0': 'zero',
    '1': 'one',
    '2': 'two',
    '3': 'three',
    '4': 'four',
    length: 5
};

var sliced = Array.prototype.slice.call( my_object, 3 );
Copier après la connexion

Remarquablement, slice() agit comme prévu, donnant le résultat souhaité :

['three','four'];
Copier après la connexion

Le même mécanisme s'applique lorsqu'un objet arguments est passé comme valeur pour this dans Array. prototype.slice.call(arguments). Puisque les arguments ont une propriété .length et un tableau d'indices numériques, slice() procède comme s'il fonctionnait sur un tableau réel, fournissant un résultat cohérent et prévisible.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal