成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Javascript利用閉包循環綁定事件

開發 前端
通過舉例介紹JavaScript利用循環綁定事件,并了解閉包相關操作。

我們先看一個關于Javascript利用循環綁定事件的例子:

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

﹤!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下面的所有li的對象數組   
    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﹥

這個例子循環為一組對象綁定事件處理函數。

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

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

﹤!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下面的所有li的對象數組   
    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﹥

測試一下你會發現alert出來的都是:這是第6記錄

其實這里for循環已將整個列表循環了一遍,并執行了i++,所以這里i變成了6,

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

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

看看什么是閉包:

閉包時是指內層的函數可以引用存在與包圍他的函數內的變量,即使外層的函數的執行已經終止。

可以查閱: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下面的所有li的對象數組   
    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中實現偽哈希表
  2. JavaScript函數調用的四個規則
  3. Javascript中的replace方法與正則表達式講解
責任編輯:book05 來源: 中國IT實驗室
相關推薦

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

前端開發javascript閉包

2021-01-13 11:25:12

JavaScript閉包函數

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微任務

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閉包表達式尾隨閉包

2021-12-06 07:15:48

Javascript作用域閉包

2015-12-22 11:48:50

javascript閉包

2020-02-12 16:58:15

JavaScript前端技術
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧洲亚洲一区 | 成人在线免费 | 欧美成人a∨高清免费观看 欧美日韩中 | 国内精品久久影院 | 午夜视频免费网站 | 亚洲视频三区 | 久久久男人的天堂 | 99成人精品 | 日本免费一区二区三区 | 欧美国产精品一区二区三区 | 欧美一区二区三区在线观看 | 在线免费av电影 | 91久久久久久久久 | 国产日韩一区二区 | 亚洲a在线观看 | 91久久综合 | 伊人久久综合 | 国产高清在线视频 | 91在线观看网址 | 日韩在线视频网址 | 日韩高清国产一区在线 | 一区二区亚洲 | 在线观看的av | 国产视频一二三区 | 日批日韩在线观看 | 男人的天堂久久 | 成人免费网站视频 | 国产精品亚洲精品久久 | 亚洲一区二区三区在线 | 成人精品视频在线观看 | 日韩国产精品一区二区三区 | 亚洲成人精品一区 | 国产精品久久7777777 | 久久久www成人免费精品张筱雨 | 久久精品一级 | 日韩精品一区中文字幕 | 一级片免费视频 | 精品国产一区二区三区在线观看 | 在线观看亚洲专区 | a视频在线观看 | 亚洲 自拍 另类 欧美 丝袜 |