>웹 프론트엔드 >JS 튜토리얼 >js의 DOM 이벤트 바인딩 분석

js의 DOM 이벤트 바인딩 분석

亚连
亚连원래의
2018-05-29 15:41:541403검색

이 기사에서는 JS의 DOM 이벤트 바인딩에 대한 관련 지식 포인트를 정리했습니다. 관심 있는 친구들은 빠르게 배우고 참고할 수 있습니다.

js 이벤트 바인딩

JavaScript에는 세 가지 이벤트 모델이 있습니다.

  • 인라인 모델

  • 스크립트 모델

  • DOM2 모델

1.

//基本废除不用
<input type="button" value="按钮" onclick="alert(&#39;Lee&#39;);" />
<input type="button" value="按钮" onclick="box();" />

2. 스크립트 model

//基本不用
var input = document.getElementsByTagName(&#39;input&#39;)[0]; //得到 input 对象
 input.onclick = function () { //匿名函数执行
 alert(&#39;Lee&#39;);
};
事件处理函数 影响的元素 何时发生
onabort 图像 当图像加载被中断时
onblur 窗口、框架、所有表单对象 当焦点从对象上移开时
onchange 输入框,选择框和文本区域 当改变一个元素的值且失去焦点时
onclick 链接、按钮、表单对象、图像映射区域 当用户单击对象时
ondblclick 链接、按钮、表单对象 当用户双击对象时
ondragdrop 窗口 当用户将一个对象拖放到浏览器窗口时
onError 脚本 当脚本中发生语法错误时
onfocus 窗口、框架、所有表单对象 当单击鼠标或者将鼠标移动聚焦到窗口或框架时
onkeydown 文档、图像、链接、表单 当按键被按下时
onkeypress 文档、图像、链接、表单 当按键被按下然后松开时
onkeyup 文档、图像、链接、表单 当按键被松开时
onload 主题、框架集、图像 文档或图像加载后
onunload 主体、框架集 文档或框架集卸载后
onmouseout 链接 当图标移除链接时
onmouseover 链接 当鼠标移到链接时
onmove 窗口 当浏览器窗口移动时
onreset 表单复位按钮 单击表单的 reset 按钮
onresize 窗口 当选择一个表单对象时
onselect 表单元素 当选择一个表单对象时
onsubmit 表单 当发送表格到服务器时

3. 인라인 모델

"DOM2 수준 이벤트"는 이벤트를 추가하고 이벤트 핸들러를 제거하는 두 가지 메서드,

addEventListener() 및 RemoveEventListener()를 정의합니다. 이 두 가지 메소드는 모든 DOM 노드에 포함되어 있으며 둘 다 3개의 매개변수를 허용합니다. 이벤트 이름, 함수, 버블링 또는 캡처된 부울 값(true는 캡처를 의미하고 false는 버블링을 의미함)

window.addEventListener(&#39;load&#39;, function () {
 alert(&#39;Lee&#39;);
}, false);
window.removeEventListener(&#39;load&#39;, function () {
 alert(&#39;Mr.Lee&#39;);
}, false)

PS: IE는 DOM에서 동일한 두 가지 유사한 메소드를 구현합니다. : attachmentEvent() 및 detachEvent(). 두 방법 모두 동일한 매개변수(이벤트 이름 및 기능)를 허용합니다.


이 두 가지 기능 세트를 사용할 때 먼저 차이점에 대해 이야기해 보겠습니다.

1. IE 不支持捕获,只支持冒泡;
2. IE 添加事件不能屏蔽重复的函数;
3. IE 中的 this 指向的是 window 而不是 DOM 对象。
4. 在传统事件上,IE 是无法接受到 event 对象的,但使用了 attchEvent()却可以,但有些区别。
"javascript
window.attachEvent(&#39;load&#39;, function () {
 alert(&#39;Lee&#39;);
}, false);
window.detachEvent(&#39;load&#39;, function () {
 alert(&#39;Mr.Lee&#39;);
}, false)
"

PS: IE의 이벤트 바인딩 기능인 attachmentEvent() 및 detachEvent()는 실제로 사용되지 않을 수 있습니다.

1 .IE9는 W3C의 이벤트 바인딩 기능을 완벽하게 지원합니다.

3. IE의 이벤트 바인딩 기능은

4. , 차단되지 않았습니다. 5. 메모리 누수 문제가 있습니다. 위 내용은 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

vue-cli axios 요청 방법 및 도메인 간 처리 문제

Vue 페이지 로딩 깜박임 문제

js가 ModelAndView 값을 얻는 문제에 대한 간단한 토론

위 내용은 js의 DOM 이벤트 바인딩 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.