js原生添加事件的方式

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js原生添加事件的方式相关的知识,希望对你有一定的参考价值。

js原生添加事件的方式:

1. 直接在html标签上添加

<div onclick="alert(‘div‘)">div</div>

2. domon...方法添加

document.getElementById(‘div‘).onclick = function () {alert(‘div‘)};

3. addEventListenerattachEvent添加

document.getElementById(‘div‘).addEventListener(‘click‘, function () {alert(‘div‘)}, false);

 

 

原生js事件绑定和事件移除

/**  

 * @description 事件绑定,兼容各浏览器  

 * @param target 事件触发对象   

 * @param type   事件  

 * @param func   事件处理函数  

 */  

function addEvents(target, type, func) {  

    if (target.addEventListener)    //ie ie9  

        target.addEventListener(type, func, false);  

// addEventListener当然就是注册事件,她有三个参数,分别为:"事件名称", "事件回调", "捕获/冒泡"。最后一个参数是布尔型,true代表捕获事件,false代表冒泡事件。

    else if (target.attachEvent)   //ie6ie8  

        target.attachEvent("on" + type, func);  

    else target["on" + type] = func;   //ie5  

};  

 

/**  

 * @description 事件移除,兼容各浏览器  

 * @param target 事件触发对象  

 * @param type   事件  

 * @param func   事件处理函数  

 */  

function removeEvents(target, type, func){  

    if (target.removeEventListener)  

        target.removeEventListener(type, func, false);  

    else if (target.detachEvent)  

        target.detachEvent("on" + type, func);  

    else target["on" + type] = null;  

};  

/**btn.removeEventListener("事件名称", "事件回调", "捕获/冒泡");这和绑定事件的参数一样,详细说明下:        

·  事件名称,就是说解除哪个事件呗。

·  事件回调,是一个函数,这个函数必须和注册事件的函数是同一个。

·  事件类型,布尔值,这个必须和注册事件时的类型一致。

*/

原生javascript事件详解:http://www.cnblogs.com/iyangyuan/p/4190773.html

以上是关于js原生添加事件的方式的主要内容,如果未能解决你的问题,请参考以下文章

原生js怎么为动态生成的标签添加各种事件

原生js为元素添加事件

原生JS获取元素,添加事件

js原生模拟点击事件

原生jsjs动态添加dom,如何绑定事件

iOS开发漫话WKWebView之给H5网页图片添加点击事件以实现原生图片预览