js 循环函数

JavaScript025

js 循环函数,第1张

js如下

<script>

function showCont()

{

var bt=document.getElementById("Play")

var s=document.getElementById("fla")

var f=document.getElementById("show")

if(s.style.display=="")

{

s.style.display="none"

f.style.display=""

bt.innerText="点击缩进全文"

}

else

{

s.style.display=""

f.style.display="none"

bt.innerText="点击展开全文"

}

}

</script>

【引申】:

1. 名叫 div 的变量有一个对 handler 的引用(因为 handler 是它的一个属性)

2. handler 也同样有一个对 div 的引用(因为 div 处于它的作用域内。这是js闭包的特性,函数内的代码可以引用函数外的变量)

3. 这就造成了循环引用,最后两个变量都不会被销毁,成了内存泄露

按照这个说法,像下面这样写代码就不会出现这种内存泄露了。

因为 div 变量不再处于 handler 函数的作用域之中。

第一种方法,利用闭包:

function addfun(){

 var buttonNodes = document.getElementsByTagName("input")

 for (var x = 0x <buttonNodes.lengthx++) {

    (function(x){

       buttonNodes[x].onclick=function(){

          alert(x)

       }

    })(x)

 }

}

第二种方法,利用自定义属性值:

function addfun(){

 var buttonNodes = document.getElementsByTagName("input")

 for (var x = 0x <buttonNodes.lengthx++) {

    buttonNodes[x].index=x

    buttonNodes[x].onclick=function(){

       alert(this.index)

    }

 }

}

第三种方法,利用ES6的新特性:

function addfun(){

 var buttonNodes = document.getElementsByTagName("input")

 for (let x = 0 x <buttonNodes.lengthx++) {

    buttonNodes[x].onclick=function(){

       alert(x)

    }

 }

}