中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

解決使用attachEvent函數(shù)時,this指向被綁定的元素的問題的方法

使用attachEvent對同一事件進(jìn)行多次綁定,這是解決事件函數(shù)定義沖突的重要方法。但是在IE中,函數(shù)內(nèi)的this指針并沒有指向被綁定元素,而是function對象,在應(yīng)用中,這是很難受的一件事,如果試圖用局部變量傳送元素,會因為閉包而引起內(nèi)存泄漏。那么,我們應(yīng)該如何解決這一難題呢?

   我給Function添加了原型方法“bindNode”,在這個方法里,根據(jù)傳送過來的元素,進(jìn)行全局性存儲轉(zhuǎn)換,然后返回經(jīng)過封裝的函數(shù),使用call方法來進(jìn)行屬主轉(zhuǎn)換。



<html>
<body>
<button id=btTest>test</button>
</body>
</html>
<script>
if(!document.all){
   HTMLElement.prototype.attachEvent=function(sType,foo){
       this.addEventListener(sType.slice(2),foo,false)
   }
}
Function.prototype.bindNode=function(oNode){
   var foo=this,iNodeItem

   //使用了全局?jǐn)?shù)組__bindNodes,通過局部變量iNodeItem進(jìn)行跨函數(shù)傳值,如果直接傳送oNode,也將造成閉包
   if(window.__bindNodes==null)
       __bindNodes=[]
   __bindNodes.push(oNode)
   iNodeItem=__bindNodes.length-1
   oNode=null
   return function(e){
       foo.call(__bindNodes[iNodeItem],e||event)
   }
}
abc()
function abc(){
   var bt=document.getElementById("btTest")
   bt.attachEvent("onclick",function(){

       //如果不經(jīng)過bindNode處理,下面的結(jié)果將是undefined
       alert(this.tagName)
   }.bindNode(bt))
   bt=null
}
</script>

JavaScript技術(shù)解決使用attachEvent函數(shù)時,this指向被綁定的元素的問題的方法,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 免费精品一区 | 一本一道久久a久久精品综合 | 欧美日韩国产一区二区三区 | 亚洲草草视频 | 国产成人免费 | 黄色小视频入口 | 羞羞色影院| 在线日韩欧美 | 91手机精品视频 | 在线四虎 | 精品视频一区二区三区 | 欧美激情一区二区三区 | 久久久久久女 | 亚洲综合一区二区三区 | 成人免费福利 | 国产欧美三区 | 日本五月婷婷 | 国产日韩精品视频 | 亚洲综合色视频在线观看 | 国内精品一区二区三区 | 天天草天天爱 | 中文字幕亚洲欧美 | 午夜天堂精品久久久久 | 黄免费观看视频 | 一区二区三区在线观看视频 | 欧美日韩在线观看视频 | 久久久不卡网国产精品一区 | 国产精品久久久久久福利一牛影视 | 成人免费观看男女羞羞视频 | 久久黄网 | 久久国产精品一区 | 一级大黄色片 | 国产a视频 | 韩日精品视频 | 久久精品91久久久久久再现 | 欧美日日 | 91精品国产欧美一区二区成人 | 国产目拍亚洲精品99久久精品 | 国产一级毛片视频 | 国产午夜精品久久久 | 天天操网 |