成人免费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閉包

2021-01-22 07:48:07

JavaScript 高階函數閉包
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲成人二区 | 国产日韩av一区二区 | 国产精品视频网 | 祝你幸福电影在线观看 | 精品国产乱码久久久久久影片 | 国产亚洲区 | 欧美一区二区三区四区视频 | 亚洲精品免费视频 | 亚洲最大看片网站 | 日韩在线小视频 | 本地毛片 | 久久国内精品 | 免费高潮视频95在线观看网站 | 欧美乱人伦视频 | 欧美精品国产精品 | 91亚洲国产成人久久精品网站 | 精品久久久久久久 | 亚洲三区在线观看 | 久久噜噜噜精品国产亚洲综合 | 一区二区精品 | 成人av鲁丝片一区二区小说 | 一区二区精品 | 久久精品无码一区二区三区 | 欧美日韩在线看 | 少妇一级淫片免费播放 | 91精品国产综合久久久久久漫画 | 欧美大片一区 | 国产91久久久久蜜臀青青天草二 | 美女天天操 | 亚洲高清av在线 | 国产三级电影网站 | 欧美视频免费在线 | 中文字幕在线观看一区 | www.国产一区| 国产日韩欧美中文 | 亚州毛片| 亚洲欧美一区二区三区国产精品 | 国产成年人小视频 | 亚洲高清视频一区二区 | 午夜视频一区二区 | 天堂色 |