自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Javascript利用閉包循環(huán)綁定事件

開發(fā) 前端
通過舉例介紹JavaScript利用循環(huán)綁定事件,并了解閉包相關(guān)操作。

我們先看一個關(guān)于Javascript利用循環(huán)綁定事件的例子:

例如:一個不確定長度的列表,在鼠標經(jīng)過某一條的時候改變背景。

﹤!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "﹤html xmlns="﹤head﹥  
    ﹤title﹥Untitled Page﹤/title﹥  
﹤/head﹥  
﹤body﹥  
﹤ul id="list"﹥  
﹤li﹥第1條記錄﹤/li﹥  
﹤li﹥第2條記錄﹤/li﹥  
﹤li﹥第3條記錄﹤/li﹥  
﹤li﹥第4條記錄﹤/li﹥  
﹤li﹥第5條記錄﹤/li﹥  
﹤li﹥第6條記錄﹤/li﹥  
﹤/ul﹥  
﹤script type="text/javascript"﹥  
    var list_obj = document.getElementById("list").getElementsByTagName("li"); //獲取list下面的所有l(wèi)i的對象數(shù)組   
    for (var i = 0; i ﹤= list_obj.length; i++) {   
        list_obj[i].onmousemove = function() {   
            this.style.backgroundColor = "#cdcdcd";   
        }   
        list_obj[i].onmouseout = function() {   
        this.style.backgroundColor = "#FFFFFF";   
        }   
    }   
﹤/script﹥  
﹤/body﹥  
﹤/html﹥

這個例子循環(huán)為一組對象綁定事件處理函數(shù)。

但是,如果我們在這個基礎(chǔ)上增加一些需求。比如在點擊某一條記錄的時候彈出這是第幾條記錄?

可能你會理所當然的這么寫:

﹤!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "﹤html xmlns="﹤head﹥  
    ﹤title﹥Untitled Page﹤/title﹥  
﹤/head﹥  
﹤body﹥  
﹤ul id="list"﹥  
﹤li﹥第1條記錄﹤/li﹥  
﹤li﹥第2條記錄﹤/li﹥  
﹤li﹥第3條記錄﹤/li﹥  
﹤li﹥第4條記錄﹤/li﹥  
﹤li﹥第5條記錄﹤/li﹥  
﹤li﹥第6條記錄﹤/li﹥  
﹤/ul﹥  
﹤script type="text/javascript"﹥  
    var list_obj = document.getElementById("list").getElementsByTagName("li"); //獲取list下面的所有l(wèi)i的對象數(shù)組   
    for (var i = 0; i ﹤= list_obj.length; i++) {   
        list_obj[i].onmousemove = function() {   
            this.style.backgroundColor = "#cdcdcd";   
        }   
        list_obj[i].onmouseout = function() {   
            this.style.backgroundColor = "#FFFFFF";   
        }   
        list_obj[i].onclick = function() {   
            alert("這是第" + i + "記錄");   
        }   
    }   
﹤/script﹥  
﹤/body﹥  
﹤/html﹥

測試一下你會發(fā)現(xiàn)alert出來的都是:這是第6記錄

其實這里for循環(huán)已將整個列表循環(huán)了一遍,并執(zhí)行了i++,所以這里i變成了6,

有什么好的辦法解決這個問題嗎?

那就是閉包了,個人認為閉包是js中最難捉摸的地方之一,

看看什么是閉包:

閉包時是指內(nèi)層的函數(shù)可以引用存在與包圍他的函數(shù)內(nèi)的變量,即使外層的函數(shù)的執(zhí)行已經(jīng)終止。

可以查閱:http://www.css88.com/article.asp?id=469

這個例子中我們可以這樣做:

﹤!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "﹤html xmlns="﹤head﹥  
    ﹤title﹥Untitled Page﹤/title﹥  
﹤/head﹥  
﹤body﹥  
﹤ul id="list"﹥  
﹤li﹥第1條記錄﹤/li﹥  
﹤li﹥第2條記錄﹤/li﹥  
﹤li﹥第3條記錄﹤/li﹥  
﹤li﹥第4條記錄﹤/li﹥  
﹤li﹥第5條記錄﹤/li﹥  
﹤li﹥第6條記錄﹤/li﹥  
﹤/ul﹥  
﹤script type="text/javascript"﹥  
    function tt(nob) {   
        this.clickFunc = function() {   
        alert("這是第" + (nob + 1) + "記錄");   
        }   
    }   
    var list_obj = document.getElementById("list").getElementsByTagName("li"); //獲取list下面的所有l(wèi)i的對象數(shù)組   
    for (var i = 0; i ﹤= list_obj.length; i++) {   
        list_obj[i].onmousemove = function() {   
            this.style.backgroundColor = "#cdcdcd";   
        }   
        list_obj[i].onmouseout = function() {   
            this.style.backgroundColor = "#FFFFFF";   
        }   
        var col = new tt(i);   
        list_obj[i].onclick = col.clickFunc;   
    }   
﹤/script﹥  
﹤/body﹥  
﹤/html﹥

【編輯推薦】

  1. 在Javascript中實現(xiàn)偽哈希表
  2. JavaScript函數(shù)調(diào)用的四個規(guī)則
  3. Javascript中的replace方法與正則表達式講解
責(zé)任編輯:book05 來源: 中國IT實驗室
相關(guān)推薦

2021-02-21 16:21:19

JavaScript閉包前端

2020-10-14 15:15:28

JavaScript(

2011-05-25 14:48:33

Javascript閉包

2017-09-14 13:55:57

JavaScript

2016-09-14 09:20:05

JavaScript閉包Web

2009-07-24 17:30:37

Javascript閉

2012-11-29 10:09:23

Javascript閉包

2010-06-23 10:24:42

Javascript閉

2016-09-18 20:53:16

JavaScript閉包前端

2017-05-22 16:08:30

前端開發(fā)javascript閉包

2021-01-13 11:25:12

JavaScript閉包函數(shù)

2016-09-06 21:23:25

JavaScriptnode異步

2021-01-18 08:24:51

JavaScriptMicrotask微任務(wù)

2011-03-02 12:33:00

JavaScript

2011-05-12 18:26:08

Javascript作用域

2011-05-30 14:41:09

Javascript閉

2024-01-22 09:51:32

Swift閉包表達式尾隨閉包

2021-12-06 07:15:48

Javascript作用域閉包

2011-08-03 08:59:46

JavaScript

2019-07-09 10:43:57

JavaScriptWeb前端
點贊
收藏

51CTO技術(shù)棧公眾號