<!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>Document</title>
</head>
<body>
<button id="btn1">btn1</button>
<button id="btn2">btn2</button>
<script>
/**
* 不同点:
* 1.addEventListener是符合W3C规范的标准方法,attachEvent是IE低版本的非标准方法
* 2.addEventListener支持事件捕获也支持事件冒泡,而attachEvent只支持事件捕获
* 3.attachEvent第一个参数是onXX,addEventListener是直接XX
* 4.当定义多个监听事件时,addEventListener是从上到下执行,attachEvent是从下往上执行
*
* 注意:
* attachEvent既然用于IE低版本,那么回调函数就不要使用箭头函数,会不兼容
*/
let btn1 = document.getElementById("btn1");
let btn2 = document.getElementById("btn2");
if (document.attachEvent) {
// IE
btn1.attachEvent("onclick", function (e) {
console.log(1)
})
btn1.attachEvent("onclick", function (e) {
console.log(2)
})
} else {
// google
btn2.addEventListener("click", function (e) {
console.log(3)
})
btn2.addEventListener("click", function (e) {
console.log(4)
})
}
</script>
</body>
</html>