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