3つの方法JSイベントは、結合、およびIEの文言と互換性があります

イベントは、3つに分割結合
HTMLに結合1.直接
結合2.DOM0レベルイベント
バインディング3.DOM2レベルのイベントを

HTML

<body>
    <button onclick="get()">按钮</button>
    <button id="btn">DOM0级事件</button>
    <button id="btn2">DOM2级事件绑定</button>
</body>

JS

//绑定事件满足3步:
//1.事件对象   button
//2.绑定一个事件类型
//3.事件句柄 (事件处理函数)

//添加事件
function get(){
    console.log(1)
}
var btn=document.getElementById("btn")
var btn2=document.getElementById("btn2")
var dom0=function(){
    console.log("DOM0级事件")
}
var dom2=function(){
    console.log("DOM2级事件")
}
btn.onclick=dom0
btn2.addEventListener("click",dom2,false)
//兼容IE8
btn2.attachEvent("onclick",dom2)
//移除事件
btn2.removeEventListener("click",dom2)
//移除事件IE8
btn2.detachEvent("onlick",dom2)

IEの文言に対応

var key={
    addEvent:function(element,type,fun){
        if(element.addEventListener){
            element.addEventListener(type,fun)
        }else if(element.attachEvent){
            element.attachEvent("on"+type,fun)
        }else{
            element["on"+type]=null
        }
    },
    removeEvent:function(element,type,fun){
        if(element.addEventListener){
            element.removeEventListener(type,fun)
        }else if(element.attachEvent){
            element.detachEvent("on"+type,fun)
        }else{
            element["on"+type]=null
        }
    }
}
key.addEvent(btn2,"click",dom2)
key.removeEvent(btn2,"click",dom2)
公開された25元の記事 ウォンの賞賛0 ビュー636

おすすめ

転載: blog.csdn.net/JamesHKK/article/details/104771005