偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

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

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

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

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

﹤!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﹥

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

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

可能你會(huì)理所當(dā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";   
        }   
        list_obj[i].onclick = function() {   
            alert("這是第" + i + "記錄");   
        }   
    }   
﹤/script﹥  
﹤/body﹥  
﹤/html﹥

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

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

有什么好的辦法解決這個(gè)問題嗎?

那就是閉包了,個(gè)人認(rèn)為閉包是js中最難捉摸的地方之一,

看看什么是閉包:

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

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

這個(gè)例子中我們可以這樣做:

﹤!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中實(shí)現(xiàn)偽哈希表
  2. JavaScript函數(shù)調(diào)用的四個(gè)規(guī)則
  3. Javascript中的replace方法與正則表達(dá)式講解
責(zé)任編輯:book05 來源: 中國IT實(shí)驗(yàn)室
相關(guān)推薦

2021-02-21 16:21:19

JavaScript閉包前端

2020-10-14 15:15:28

JavaScript(

2011-05-25 14:48:33

Javascript閉包

2016-09-14 09:20:05

JavaScript閉包Web

2009-07-24 17:30:37

Javascript閉

2017-09-14 13:55:57

JavaScript

2010-06-23 10:24:42

Javascript閉

2017-05-22 16:08:30

前端開發(fā)javascript閉包

2021-01-13 11:25:12

JavaScript閉包函數(shù)

2016-09-18 20:53:16

JavaScript閉包前端

2012-11-29 10:09:23

Javascript閉包

2016-09-06 21:23:25

JavaScriptnode異步

2021-01-18 08:24:51

JavaScriptMicrotask微任務(wù)

2011-05-12 18:26:08

Javascript作用域

2011-05-30 14:41:09

Javascript閉

2011-03-02 12:33:00

JavaScript

2024-01-22 09:51:32

Swift閉包表達(dá)式尾隨閉包

2021-12-06 07:15:48

Javascript作用域閉包

2015-12-22 11:48:50

javascript閉包

2020-02-12 16:58:15

JavaScript前端技術(shù)
點(diǎn)贊
收藏

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