天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

講兩件事:1.this指針的用法小探. 2.ie的attachEvent和firefox的addEventListener在事件處理上的區別

第一件事情.
this 指鐘是JavaScript語言中的一個特殊指鐘,他在代碼運行時,指向調用this語句的當前對象.
如果是事件綁定函數,則指向被綁定的元素本身.
<script type="text/Javascript">
//by Go_Rush(阿舜) from  http://ashun.cnblogs.com/
alert(this===window)  //true  直
接調用的時候,指向window本身
var gorush={
    f:function(){
        alert(this===gorush)    //true
    }
}
gorush.f()   //指向 gorush對象
document.onclick=function(){   
    alert(this===document)  //true ,指向 document
}
/*
element.onclick=function(){
    alert(this===element)     //true
}
*/
</script>
特別要值得注意的是,當多個對象嵌套的時候, this 是指向最近調用它的那個對象的
obj1={
    obj2:{
        f:function(){
            alert(this===obj1.obj2)  //這里 this 并不是指向 obj1的哦。
        }
    }
}
obj1.obj2.f()
再舉一個非常容易出錯的例子,  點這里看相關鏈接
<script type="text/Javascript">
//by Go_Rush from http://ashun.cnblogs.com/
//以下gorush1中 this的用法是錯誤的,這個錯誤10個程序員6個犯
var gorush1={
    showMsg:function(){alert("hello,world")},
    doAjax:function(){
        new Ajax.Request("index.php",{onSuccess:function(){
            this.showMsg()
        }})
    }         
}
//gorush2中的才是對的
var gorush2={
    showMsg:function(){alert("hello,world")},
    doAjax:function(){
        var self=this;    //備份 gorush2對象 
        new Ajax.Request("index.php",{onSuccess:function(){
            self.showMsg()
        }})
    }         
}
</script>

第二件事情:
   閑話不多說,先上碟小菜.
<script type="text/Javascript">
var btn=null
window.onload=function(){
    btn=document.getElementById("btn")    
    if (window.attachEvent) btn.attachEvent("onclick",gorush);
    if (window.addEventListener) btn.addEventListener("click",gorush,false)
}
function gorush(){
    if (this===window) alert("this==window")   //ie6.0下,這句會執行
    if (this===btn)        alert("this==btn")        //ff1.5下,  這句會執行
}
</script>
<input type="button" value="click me" id="btn">
真不明白為什么 ie 會這樣搞,讓人很郁悶啊,為什么把 this 指向 window呢?
解決方法:
1. 事件綁定的時候不要用 attachEvent, 可憐的我,當時就是用的prototype.js的Event.Observe方法
這樣 element.onclick=function.....  這樣在兩個瀏覽器中 this 指鐘都指向 element
2. 在處理函數 gorush中 用 getEvent()方法統一獲取事件,然后在用 evt.srcElement || evt.target 獲取 element對象

JavaScript技術講兩件事:1.this指針的用法小探. 2.ie的attachEvent和firefox的addEventListener在事件處理上的區別,轉載需保留來源!

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

主站蜘蛛池模板: 果冻传媒视频在线播放 | 日韩高清在线亚洲专区 | 一个人的免费完整在线观看HD | 国产欧美一区二区精品久久久 | 亚洲视频国产 | 无码人妻99久久密AV | 511麻豆视传媒精品AV | 欧美一区二区三区男同 | 亚洲精品卡2卡3卡4卡5卡区 | 人妻换人妻AA视频 | 成人在无码AV在线观看一 | 亚洲三级在线视频 | 日韩欧美亚洲精品综合在线 | 国产专区_爽死777 | 巨胸美女狂喷奶水www网麻豆 | 国内高清在线观看视频 | 最近的2019中文字幕国语HD | 97国产揄拍国产精品人妻 | 丰满的美女射精动态图 | 国产女人乱人伦精品一区二区 | 久久免费精品一区二区 | 日韩欧美一区二区三区免费观看 | 一本之道高清在线观看免费 | 国产午夜在线观看视频 | 中国xxxxxz| 国产高潮国产高潮久久久久久 | 受喷汁红肿抽搐磨NP双性 | 最近免费中文字幕MV免费高清 | 久久九九亚洲精品 | 97超级碰久久久久香蕉人人 | 国自产精品手机在线视频 | 成 人 免费 黄 色 网站无毒下载 | 成年人免费在线视频观看 | 寻找最美乡村教师颁奖晚会 | 国产在线成人一区二区三区 | 亚州AV中文无码乱人伦在线 | 精品国产自在现线拍国语 | 日韩成人黄色 | 亚洲九九视频 | 国产色欲一区二区精品久久呦 | 成人影片下载网站 |