이번에는 js를 사용하여 프로젝트에서 DOM 이벤트를 바인딩하는 방법을 보여 드리겠습니다. js를 사용하여 프로젝트에서 DOM 이벤트를 바인딩할 때 주의할 점은 무엇입니까? 다음은 실제 사례입니다.
js 이벤트 바인딩
JavaScript에는 세 가지 이벤트 모델이 있습니다.
인라인 모델
스크립트 모델
DOM2 모델
1.
//基本废除不用 <input type="button" value="按钮" onclick="alert('Lee');" /> <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)
이 두 가지 기능 세트를 사용할 때 먼저 차이점에 대해 이야기해 보겠습니다.
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 중국어 웹사이트의 다른 관련 기사를 주목하세요!
추천 도서:
파일 업로드를 위한 nodejs+express위 내용은 js를 사용하여 프로젝트에서 DOM 이벤트를 바인딩하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!