JS 学习笔记 闭包小案例

直接上代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8" />
    <title>Document</title>
</head>
<style type="text/css">
    *{
        list-style:none;
    }
    ul{
        display:flex;
        flex-wrap:wrap;
    }
    li{
        width: 20%;
        text-align: center;

    }
    img{
        width: 90%;
        padding:5%;
        border:1px solid #ccc;
        border-radius:5px;

    }
</style>
<body>
<ul>
    <li><img src="http://www.nixiaolei.com/pizza/dist/pizza.jpg" alt=""><p><button>赞(1)</button></p></li>
    <li><img src="http://www.nixiaolei.com/pizza/dist/pizza.jpg" alt=""><p><button>赞(1)</button></p></li>
    <li><img src="http://www.nixiaolei.com/pizza/dist/pizza.jpg" alt=""><p><button>赞(1)</button></p></li>
    <li><img src="http://www.nixiaolei.com/pizza/dist/pizza.jpg" alt=""><p><button>赞(1)</button></p></li>
</ul>
</body>
<script type="text/javascript">
function my$(tagName){
    return document.getElementsByTagName(tagName);
}

var btnObjs=my$("button");


function bb(){
    var value=2;
    return function(){
        var target=event.target
        console.log(this)
        this.innerHTML="赞("+(value++)+")";
    }
}


for(var i=0;i<btnObjs.length;i++){
    btnObjs[i].οnclick=bb()
}


</script>
</html>

函数被返回后 其中的value 并未被释放,所以累加

闭包后,作用域链会被延长

闭包的作用,缓存数据,是缺点也是优点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值