Maison > interface Web > js tutoriel > le corps du texte

Explication détaillée d'exemples de portée de variable JavaScript, de mémoire, de fuites DOM et d'autres problèmes

伊谢尔伦
Libérer: 2017-07-18 10:31:52
original
1426 Les gens l'ont consulté

Portée

La variable n'est pas déclarée dans la fonction ou déclarée sans var, c'est une variable globale et a une portée globale. Toutes les propriétés de l'objet window ont une portée globale. ; in Le code est accessible n'importe où. Les variables déclarées dans une fonction et modifiées avec var sont des variables locales et ne peuvent être utilisées que dans le corps de la fonction. Bien que les paramètres de la fonction n'utilisent pas var, ce sont toujours des variables locales.

Aucune portée au niveau du bloc


// if语句:

<script type="text/javascript">
if(true){            //if语句的花括号没有作用域的功能。

var box = "trigkit4";
}
alert(box);//弹出 trigkit4
</script>
Copier après la connexion

La même chose est vraie pour l'instruction de boucle for.

Requête variable

Dans la requête variable, l'accès aux variables locales est plus rapide que les variables globales, il n'est donc pas nécessaire de rechercher la chaîne de portée.
L'exemple suivant :


<script type="text/javascript">
   var name = "Jack";
   function setName(){
      var name = "trigkit4";
      return name; //从底层向上搜索变量
  }
  alert(setName());   
</script>
Copier après la connexion

Problème de mémoire

javascript dispose d'un mécanisme automatique de récupération de place, une fois les données n'est plus utilisé , vous pouvez le mettre à "null" pour libérer la référence

Référence circulaire

Un exemple très simple : un objet DOM est référencé par un Javascript objet, et en même temps Si le même objet Javascript ou un autre objet Javascript est à nouveau référencé, cet objet DOM peut provoquer une fuite de mémoire. La référence à cet objet DOM ne sera pas récupérée par le garbage collector à l'arrêt du script. Pour rompre un cycle de référence, l'objet référençant l'élément DOM ou une référence à l'objet DOM doit se voir attribuer la valeur null.

Fermeture

Lorsqu'une variable en dehors de la fermeture est introduite dans la fermeture, l'objet ne peut pas être récupéré (GC) à la fin de la fermeture.


var a = function() {
 var largeStr = new Array(1000000).join(&#39;x&#39;);
 return function() {
  return largeStr;
 }
}();
Copier après la connexion

Fuite DOM

Lorsque le COM d'origine est supprimé, la référence du nœud enfant n'est pas supprimée. Elle ne peut pas être recyclée. .


var select = document.querySelector;
var treeRef = select(&#39;#tree&#39;);
//在COM树中leafRef是treeFre的一个子结点
var leafRef = select(&#39;#leaf&#39;); 
var body = select(&#39;body&#39;);
body.removeChild(treeRef);
//#tree不能被回收入,因为treeRef还在
//解决方法:
treeRef = null;
//tree还不能被回收,因为叶子结果leafRef还在
leafRef = null;
//现在#tree可以被释放了。
Copier après la connexion

Fuites de minuterie des minuteries

Les minuteries sont également un endroit courant où des fuites de mémoire se produisent :


for (var i = 0; i < 90000; i++) {
 var buggyObject = {
  callAgain: function() {
   var ref = this;
   var val = setTimeout(function() {
    ref.callAgain();
   }, 90000);
  }
 }
 buggyObject.callAgain();
 //虽然你想回收但是timer还在
 buggyObject = null;
}
Copier après la connexion

Débogage de la mémoire

L'outil de débogage de la mémoire intégré à Chrome peut facilement visualiser l'utilisation de la mémoire et les fuites de mémoire :
Cliquez sur Enregistrer dans la chronologie - > Mémoire :

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!