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
Linda Hamiltonoriginal
2024-10-21 22:02:021078parcourir

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 );

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

['three','four'];

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!

Déclaration:
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