事件触发器从字面意思上可以很好的理解,就是用来触发事件的,但是有些没有用过的朋友可能就会迷惑了,事件不是通常都由用户在页面上的实际操作来触发的吗?这个观点不完全正确,因为有些事件必须由程序来实现,如自定义事件,jQuery的ajax框架的一些自定义事件就必须由事件触发器来实现。当然,在一些特殊情况下,用事件触发器来触发事件比用户的实际操作来触发事件更方便。
对于实现事件触发器,浏览器都有原生的方法来支持,但是在兼容性上又有很大的出入,这种兼容性的问题完全在意料之中,IE有自己的方法,其他标准浏览器也有一套方法,不说谁的方法好与不好,对于WEB开发者来说搞出几套方法就是对开发人员的一种折磨。IE支持fireEvent方法来实现事件触发,标准浏览器支持dispatchEvent来实现事件触发,两面派的IE9是两者都支持。下面是出自prototype.js的源码(其实我是从司徒正美的博客复制过来的):
var fireEvent = function(element,event){ if (document.createEventObject){ // IE浏览器支持fireEvent方法 var evt = document.createEventObject(); return element.fireEvent('on'+event,evt) } else{ // 其他标准浏览器使用dispatchEvent方法 var evt = document.createEvent( 'HTMLEvents' ); // initEvent接受3个参数: // 事件类型,是否冒泡,是否阻止浏览器的默认行为 evt.initEvent(event, true, true); return !element.dispatchEvent(evt); } };
上面的方法可以兼容主流的浏览器以实现事件触发器的功能。但是对于一些封装好的事件处理系统,如jQuery的event模块,就没这么简单了,只能通过模拟来实现了。我在之前写过一个很简单的事件处理系统,最近又碰到自定义事件的需求,于是在之前的事件系统的基础上模拟了一个事件触发器,代码如下:
/** * 事件触发器 * @param { Object } DOM元素 * @param { String / Object } 事件类型 / event对象 * @param { Array } 传递给事件处理函数的附加参数 * @param { Boolean } 是否冒泡 */ trigger : function( elem, event, data, isStopPropagation ){ var type = event.type || event, // 冒泡的父元素,一直到document、window parent = elem.parentNode || elem.ownerDocument || elem === elem.ownerDocument && win, eventHandler = $.data( elem, type + 'Handler' ); isStopPropagation = typeof data === 'boolean' ? data : (isStopPropagation || false); data = data && isArray( data ) ? data : []; // 创建自定义的event对象 event = typeof event === 'object' ? event : { type : type, preventDefault : noop, stopPropagation : function(){ isStopPropagation = true; } }; event.target = elem; data.unshift( event ); if( eventHandler ){ eventHandler.call( elem, data ); } // 递归调用自身来模拟冒泡 if( parent && !isStopPropagation ){ data.shift(); this.trigger( parent, event, data ); } }
模拟的原理并不难,给某元素绑定一个事件处理函数,如果有触发事件的实际操作就会执行相应的事件处理函数,所以要达到事件触发器的功能只要获取到相应的事件处理函数然后执行就差不多了,这是最基本的。
在实际的事件发生时浏览器会生成一个event对象,里面包含了一些事件发生时的属性和信息。如果没有实际的事件发生是没有这个event对象的,所以上面的代码也创建了一个event对象满足最基本的功能。
还有事件冒泡,如果没有实际的事件发生,自然也不会有冒泡的行为,那么如果要模拟冒泡的功能,就必须不断的查找父元素并检查是否绑定了相同类型的事件,直至到document和window为止,如果结构复杂,这种递归调用的方法性能估计会不怎么样。
最后是浏览器的默认行为,我觉得这个要去模拟相当麻烦,麻烦到不知如何去实现,比如a标签默认的跳转,我测试了jQuery的trigger,也没有实现,但是一些其他的行为貌似又在API手册中有介绍。毕竟这个功能不是很重要,暂时也没做过多的深究。
本文向大家介绍input标签内容改变的触发事件介绍,包括了input标签内容改变的触发事件介绍的使用技巧和注意事项,需要的朋友参考一下 1. onchange事件与onpropertychange事件的区别: onchange事件在内容改变(两次内容有可能相等)且失去焦点时触发;onpropertychange事件是实时触发,每增加或删除一个字符就会触发,通过js改变也会触发该事件,但是该事件是I
本文向大家介绍IOS 开发之触摸事件详细介绍,包括了IOS 开发之触摸事件详细介绍的使用技巧和注意事项,需要的朋友参考一下 IOS 触摸事件 iOS中的事件可以分为3大类型: 触摸事件 加速计事件 远程控制事件 响应者对象 在iOS中不是任何对象都能处理事件,只有继承了UIResponder的对象才能接收并处理事件。我们称之为“响应者对象”。 UIApplication、UIViewContro
本文向大家介绍JavaScript 事件对象介绍,包括了JavaScript 事件对象介绍的使用技巧和注意事项,需要的朋友参考一下 JavaScript事件的一个重要的方面是它们拥有一些相对一致的特点,可以给开发提供强大的功能; 最方便和强大的就是事件对象,它们可以帮你处理鼠标事件和键盘敲击方面的情况; 此外还可以修改一般事件的捕获/冒泡流的函数; 一 事件对象 // 通过事件对象可以获取到鼠标按
本文向大家介绍JavaScript常用事件介绍,包括了JavaScript常用事件介绍的使用技巧和注意事项,需要的朋友参考一下 JavaScript 事件(常用) 网页中的每个元素都可以产生某些可以触发 JavaScript 函数的事件。比方说,我们可以在用户点击某按钮时产生一个onClick 事件来触发某个函数。事件在HTML 页面中定义。 事件举例: 鼠标点击 页面或图像载入 鼠标悬浮于页面的
问题内容: 当有人 使用鼠标在页面上 选择给定的文本片段时, 如何 触发JavaScript函数 ? 另外,有什么方法可以 找到所选文本 在页面上的 位置 吗? 更新:更清楚地说,文本片段可以是句子或单词或短语的一部分,也可以是整个段落。 问题答案: 没有“ 选择了文本 ” 事件,但是您可以将事件绑定到。在该事件处理程序中,您可能只需检查 要么 方法。关于Stackoverflow有几个主题,例如
本文向大家介绍javascript/jquery实现点击触发事件的方法分析,包括了javascript/jquery实现点击触发事件的方法分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript/jquery实现点击触发事件的方法。分享给大家供大家参考,具体如下: 点击事件 原声态 和 jquery 感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具