Maison >interface Web >js tutoriel >Tutoriel de diagramme de passage de paramètres JavaScript

Tutoriel de diagramme de passage de paramètres JavaScript

小云云
小云云original
2018-01-03 15:21:301928parcourir

Comment passer des paramètres ? Cette fois, j'essaie de re-comprendre le passage des paramètres en JavaScript à travers un organigramme et deux exemples, j'espère que cela pourra aider tout le monde.

Emprunter une phrase au Petit Livre Rouge :

Les paramètres de toutes les fonctions dans ECMAScript sont passés par valeur

Si la valeur est un type simple, alors elle est elle-même . S'il s'agit d'un type référence, l'objet transmis est l'adresse pointant vers l'objet. Par conséquent, nous pouvons penser que tout passage de paramètre est un passage de valeur, alors comment le comprendre spécifiquement ? Jetez un œil à l'exemple :

Le premier exemple

var obj = {
    n: 1
};
function foo(data) {
    data = 2;
    console.log(data); //2
}
foo(obj);
console.log(obj.n) // 1

Ne parlons pas d'abord de la raison. Passons en revue le processus en faisant un dessin. Je pense que nous devrions pouvoir le faire. comprendre le transfert de paramètres. N'oubliez pas de passer un pointeur lors du passage d'un type référence !
Tutoriel de diagramme de passage de paramètres JavaScript
exécute d'abord var obj = {n: 1}; , ce qui peut être vu comme stockant un pointeur vers {n:1} *p
Tutoriel de diagramme de passage de paramètres JavaScript

L'étape suivante consiste à déclarer

À ce moment, le contexte d'exécution de la fonction sera créé et un objet variable sera généré, dans lequel les données du paramètre formel sont déclarées. la fonction n’est pas exécutée, la valeur actuelle n’est pas définie. Nous enregistrons l'adresse des données sous la forme 022. Pour plus de connaissances sur les objets variables, vous pouvez vous référer à l'objet variable approfondi JavaScript du professeur Yu Yu. Cet article n'aborde pas les aspects liés à l'AO. Vous devez seulement savoir que les paramètres formels ont été créés lors de la déclaration de cette fonction. function foo
Tutoriel de diagramme de passage de paramètres JavaScriptExécution
Les paramètres seront transmis, et le *p stocké dans obj sera copié dans les données à l'adresse 022, puis ils pointeront vers le même Pour un objet, si une variable change la valeur de n, la valeur de n dans l'autre variable changera également, car elle stocke un pointeur. foo(obj)
Tutoriel de diagramme de passage de paramètres JavaScript

Entrez la fonction et exécutez-la séquentiellement

A ce moment, la valeur du type de base est stockée à l'adresse 002, qui est directement stockée dans la pile, correspondant ainsi au contact perdu { dans le tas n:1}. J'imprime donc data = 2;, et constate finalement que l'objet {n:1} initialement développé n'a pas été modifié, donc console.log(data) // 2 imprime toujours 1. console.log(obj.n) // 1

Le deuxième exemple

var obj = {n:1};
(function(obj){
  console.log(obj.n); //1
  obj.n=3;
  var obj = {n:2};
  console.log(obj.n) //2
})(obj);
console.log(obj.n) //3
Dans l'ensemble, dans cet exemple, il y a un problème de couverture du même nom. Si vous ne comprenez pas très bien le déroulement de l'exécution du code, cela peut être un peu déroutant à cause du même nom, mais ce n'est pas grave. Tant que vous suivez le processus d'exécution dans l'organigramme de l'exemple précédent, vous pourrez obtenir le résultat correct.


Tutoriel de diagramme de passage de paramètres JavaScript

Déclarez la variable obj, l'adresse est 011, qui stocke le pointeur vers {n:1}*p


Tutoriel de diagramme de passage de paramètres JavaScript

déclare une fonction. Bien qu'elle ait le même nom de variable que obj, le paramètre formel obj est un attribut dans AO et n'écrasera pas le global. Il a une nouvelle adresse enregistrée comme 022 et sa valeur est. indéfini avant l'exécution.


Tutoriel de diagramme de passage de paramètres JavaScript

La fonction est exécutée immédiatement. À ce moment, l'obj global est affecté au paramètre formel obj. Nous ignorons ce problème de nommage répété. le pointeur dans 011 est *p J'en ai fait une copie et je l'ai donnée à 022. Dans le même temps, le résultat de l'exécution du premier

est 1. console.log(obj.n)
Tutoriel de diagramme de passage de paramètres JavaScript

exécute

A ce moment, le paramètre formel de la fonction, qui est obj en 022, change la valeur de n dans l'objet. obj.n=3
Tutoriel de diagramme de passage de paramètres JavaScript

L'étape la plus critique : En raison de la dénomination des objets, de nombreux enfants peuvent être un peu confus, mais suivent quand même les mêmes étapes Analysez-le simplement de cette manière. Puisque var est utilisé, un nouvel objet est déclaré et une nouvelle adresse est poussée dans la pile, enregistrée sous la forme 033, dans laquelle un nouveau pointeur est stocké pointant vers le nouvel objet {n : 2}. Par conséquent, le résultat var obj = {n:2}; imprimé plus tard doit être la valeur de n dans l'objet nouvellement ouvert. console.log(obj.n)

Enfin imprimer

Évidemment, l'objet global a changé sa valeur en 3 une fois. console.log(obj.n) //3

Résumé

Jusqu'à présent, nous avons parcouru tous les "voyages mentaux" impliquant des variables dans les deux morceaux de code ci-dessus. Puisque l'auteur n'est pas un professionnel, la description de la pile et des noms de variables s'y trouve. L'image peut ne pas être très précise. S'il y a des erreurs, n'hésitez pas à me le dire. L'essentiel est que vous puissiez comprendre ce que je veux exprimer. D'une manière générale, le point clé est qu'il existe une copie de la valeur en cours de transmission des paramètres. En même temps, si l'objet d'affectation est un type référence, un pointeur est transmis. Après avoir compris ces deux points et l'analyse. du diagramme précédent, je crois que nous rencontrerons à nouveau des problèmes similaires et que nous pouvons avoir une approche plus cohérente.

Recommandations associées :

À propos de vue-router pour implémenter le transfert de paramètres de saut entre les composants

Problèmes de saut de page HTML et de transfert de paramètres

Passage de paramètres Js et copie de variables


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