2011
Dec
19
事件处理 ,Event Binding
这篇文章将介绍如何绑定事件,触发事件,禁止浏览器的预设事件,以及删除事件的语法。假设 node 代表 html tag object, eventHandle 代表自已写的事件,event 代表 browser event object。
YUI3 Event Binding
- node.on('click',) : 绑定事件
- eventHandle.detach : 移除 eventHandle 这个事件
- event.preventDefault : 禁示预设的 Event 触发, 举例来说, a (anchor) 这个 tag 本身点击后,会导到指定的网址,如果我们不想要这个转址>的功能,可以在我们自已的 eventHandle function 中加入 event.preventDefault();
- event.stopPropagation() : 禁止多个 tag事件同时触发,当 anchor 以及他的上一层,同时绑定了 click 事件,这时,两个事件就会依序执行,但是通常我们不须上一层的事件也同时执行,这时就可以使用 stopPropagation 去停此上一层的事件。
范例
- //if box1 is a1's parent
- YUI().use('node', 'event', function (Y) {
- Y.one('#box1').on('click', function (e) {
- alert('Hello World!');
- });
- Y.one('.a1').on('click', function (e) {
- e.preventDefault();//取消预设,连结的功能
- e.stopPropagation();
- //当你点到 a1时,因为a1也在box1里面,所以box1的click事件也会触发,stopPropagation可以取消,div click的功能 (cancel Bubbling)
- alert('Hello World2!');
- this.detach(); //移除此事件
- });
- });
YUI 有个 delegate 的功能,这个功能可以将 Event 绑定在 parent tag 上,例如 anchor,与 button 的事件触发可以一起绑定在他们的 Parent div 上,范例如下。
delegate
- <div class="parent">
- <a href="xxx">anchor</a>
- <button> button</button>
- </div>
- <script>
- YUI().use('node', 'event', function (Y) {
- var bind = Y.one('.parent').delegate('click', function (E) {}, 'a, button');
- // bind.detach();
- });
- </script>
想要取消 delegate 的事件时,也可以使用 detach ,但是必需先将 event 回传值存下来,例如上一个范例是存在变数 "bind",然后再透过 bind.detach();
,将这个事件移除。
JQuery binding
JQuery 一样也可以很简单的做到 event binding .
- bind : JQuery 可以使用 bind 来绑定事件,如 $('.a').bind('click',function) ,也可以用更简短的方式,如 $('.a').click(function) 。
- event.preventDefault() : 禁止 Browser 预设的事件
- event.stopPropagation() : 禁止多个 tag事件同时触发
范例
- //if box2 is a2's parent
- $("#box2").click(function(e){
- alert('Hello World!');
- });
- $(".a2").click(function(e){
- e.preventDefault();
- e.stopPropagation();
- alert('Hello World2!');
- $(this).unbind('click');
- });
Javascrip event binding
- addEventListener , attachEvent : 纯 JS 绑定事件,要先判定浏览器,所以会用到这两个 function
- detachEvent : 移除事件
- event.preventDefault() , event.returnValue=false : 要禁止预设的事件触发,也要同时设定这两个值
- event.stopPropagation() , event.cancelBubble=true ,要停止多个 tag 事件同时触发,也要同时指定这两个值
范例
范例程式
- var eventHandle="";
- if(document.addEventListener){
- eventHandle=js_click;
- document.getElementById('a_js').addEventListener('click',eventHandle,false);
- }
- else if(document.attachEvent){
- eventHandle=js_click;
- document.getElementById('a_js').attachEvent('onclick',eventHandle);
- }
- function js_click(e){
- if ( e.preventDefault ) {
- //Firefox
- e.preventDefault();
- } else {
- //IE
- e.returnValue = false;
- }
- if ( e.stopPropagation ) {
- e.stopPropagation();
- }
- e.cancelBubble=true;
- alert('t_js');
- if(document.removeEventListener){
- this.removeEventListener('click',eventHandle,false);
- }
- else if(document.detachEvent){
- //function执行中,不能移除自已 ,所以使用 setTimeout
- setTimeout('removeEvent()',100);
- }
- }
- function removeEvent(){
- document.getElementById('a_js').detachEvent('onclick',eventHandle);
- }
回應 (Leave a comment)