>웹 프론트엔드 >JS 튜토리얼 >js에서 DOM 이벤트 바인딩 사용에 대한 팁

js에서 DOM 이벤트 바인딩 사용에 대한 팁

php中世界最好的语言
php中世界最好的语言원래의
2018-05-10 13:36:461478검색

이번에는 js에서 DOM 이벤트 바인딩을 사용하는 방법에 대한 팁을 가져오겠습니다. 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('input')[0]; //得到 input 对象
 input.onclick = function () { //匿名函数执行
 alert('Lee');
};
事件处理函数 影响的元素 何时发生
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('load', function () {
 alert('Lee');
}, false);
window.removeEventListener('load', function () {
 alert('Mr.Lee');
}, false)
PS: IE는 DOM에서 동일한 두 가지 유사한 메소드를 구현합니다. : attachmentEvent() 및 detachEvent(). 두 방법 모두 동일한 매개변수(이벤트 이름 및 기능)를 허용합니다.


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

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

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

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

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

4. , 차단되지 않았습니다.

5. 메모리 누수 문제가 있습니다.

이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요. !

추천 도서:

Angular CLI 생성 Angular 5 프로젝트 사용법 자세한 설명

Ajax 상호 작용 예를 통한 Servlet3.0 및 JS

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

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