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!