JavaScript - DOM事件的优化
因为如果在标签里面写时间的话 耦合度非常低...
所以呢 我们有
addEventListener() 和 removeEventListener() 方法可以捆绑和解绑事件:
1.addEventListener()
定义和用法
addEventListener() 方法用于向指定元素添加事件句柄。
注意: Internet Explorer 8 及更早IE版本不支持 addEventListener() 方法,,Opera 7.0 及 Opera 更早版本也不支持。 但是,对于这些不支持该函数的浏览器,你可以使用 attachEvent() 方法来添加事件句柄
语法 注意 !参1 不带 on 比如 onclck事件 就写 clck啊!
element.addEventListener(event, function, useCapture)参数 | 描述 |
---|---|
event | 必须。字符串,指定事件名。 注意: 不要使用 "on" 前缀。 例如,使用 "click" ,而不是使用 "onclick"。 提示: 所有 HTML DOM 事件,可以查看我们完整的 HTML DOM Event 对象参考手册。 |
function | 必须。指定要事件触发时执行的函数。 当事件对象会作为第一个参数传入函数。 事件对象的类型取决于特定的事件。例如, "click" 事件属于 MouseEvent(鼠标事件) 对象。 |
useCapture | 可选。布尔值,指定事件是否在捕获或冒泡阶段执行。 可能值:
|
2.addEventListener()
定义和用法
removeEventListener() 方法用于移除由 addEventListener() 方法添加的事件句柄。
注意: 如果要移除事件句柄,addEventListener() 的执行函数必须使用外部函数,
匿名函数,是无法移除的。
语法
element.removeEventListener(event, function, useCapture)
参数值
Parameter | Description |
---|---|
event | 必须。要移除的事件名称。. 注意:不要使用 "on" 前缀。 例如,使用 "click" ,而不是使用 "onclick"。 提示: 所有 HTML DOM 事件,可以查看我们完整的 HTML DOM Event 对象参考手册。 |
function | 必须。指定要移除的函数。 |
useCapture | 可选。布尔值,指定移除事件句柄的阶段。 可能值:
|
注意他们的调用者是他们的元素节点啊!
还是上个例子吧:
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>javascript study</title> </head> <body> <p>点我</p> <script type="text/javascript"> let ele = document.getElementsByTagName('p')[0]; ele.addEventListener("click" ,fun,false); function fun(){ document.write("ok!"); } </script> </body> </html>