定义和用法
triggerHandler() 方法触发被选元素的指定事件类型。但不会执行浏览器默认动作,也不会产生事件冒泡。
triggerHandler() 方法与 trigger() 方法类似。不同的是它不会触发事件(比如表单提交)的默认行为,而且只影响第一个匹配元素。
与 trigger() 方法相比的不同之处
triggerHandler()
不会触发执行元素的默认行为(例如链接click事件默认的跳转行为,表单submit事件默认的提交行为)。triggerHandler()
触发的事件不会在DOM树中冒泡,因此事件不会冒泡传递到它的任何祖辈元素,如果目标元素不直接处理它们,则不会发生任何事情。triggerHandler()
的返回值是对应事件处理函数的返回值,而不是当前jQuery对象本身。
- .trigger() 会操作 jQuery 对象匹配的所有元素,而 .triggerHandler() 只影响第一个匹配元素。
- 该方法的返回的是事件处理函数的返回值,而不是具有可链性的 jQuery 对象。此外,如果没有处理程序被触发,则这个方法返回 undefined。
触发事件
规定被选元素要触发的事件。
语法
$(selector).triggerHandler(event,[param1,param2,...])
event 必需。规定指定元素要触发的事件。
[param1,param2,...] 可选。传递到事件处理程序的额外参数。
实例:
$("button").click(function(){
$("input").triggerHandler("select");
});
对于triggerHandler()
不会触发执行元素的默认行为(例如链接click事件默认的跳转行为),有一个实际经验,
我想调用一个链接的点击事件。
想通过方法:$('#backButton').triggerHandler("click") 触发,结果无效。后来直接通过$('#backButton').click();触发。