1 <div id="switcher" class="switcher"> 2 <h3>Style Switcher</h3> 3 <button id="switcher-default">Default</button> 4 <button id="switcher-narrow">Narrow</button> 5 <button id="switcher-large">Large</button> 6 </div> 7 <script type="test/javascript"> 8 function func(){ 9 if(!$(event.target).is('button')){ 10 $('#switcher button').toggle('slow'); 11 } 12 } 13 function setBodyClass(classname){ 14 //... 15 } 16 $('#switcher').on('click',function(){ 17 if($(event.target).is('button')){ 18 var classbody=event.target.id.split('-')[1]; 19 setBodyClass(classbody); 20 } 21 }).on('click',func); 22 $('#switcher').trigger('click'); 23 </script>
1 $('#switcher').on('click',function(){ 2 //if($(event.target).is('button')){ 3 // var classbody=event.target.id.split('-')[1]; 4 //setBodyClass(classbody); 5 //} 6 console.log(event); 7 }); 8 9 $('#switcher').trigger('click');
迷惑不解的我查看了下jQuery官方文档最后一句说:“尽管 trigger() 模仿了激活事件的作用,完成与合成事件对象,它不完全复制的天然发生的事件”。为啥文档居然说有事件对象,只不过这个事件对象和天然的事件对象不一样。之前我还以为人工触发是不是就没有 event 事件对象,人工触发只是在机械地执行事件处理程序才导致的 undefined 。。。
As of jQuery 1.3,.trigger()
ed events bubble up the DOM tree; an event handler can stop the bubbling by returningfalse
from the handler or calling the.stopPropagation()
method on the event object passed into the event. Although.trigger()
simulates an event activation, complete with a synthesized event object, it does not perfectly replicate a naturally-occurring event.
既然没有 event 就执行不了,那就造一个事件对象,看到官网给了这样的示例,自行创建一个 jQuery.Event() 的实例事件对象:
var event = jQuery.Event( "submit" );
$( "form:first" ).trigger( event );
if ( event.isDefaultPrevented() ) {
// Perform an action...
}
1 $('#switcher').on('click',function(event){ 2 if($(event.target).is('button')){ 3 var classbody=event.target.id.split('-')[1]; 4 setBodyClass(classbody); 5 } 6 console.log(event) 7 }).on('click',func); 8 9 var e=jQuery.Event('click');//可以省略new 关键字 10 $('#switcher').trigger(e);
看看这个自创的事件对象是什么东西, target 属性终于是我想要的了。
2.创建 jQuery.Event 实例对象方式二 ele.trigger('eventType') 直接创建
//包含事件处理程序1
1 $(document).ready(function(){ 2 $('#switcher').trigger('click');
3 })
//包含事件处理程序2 4 $('#switcher').on('click',function(){ 5 console.log(event); 6 if($(event.target).is('button')){ 7 var classbody=event.target.id.split('-')[1]; 8 setBodyClass(classbody); 9 } 10 })
target 是 document ,可以看出 trigger() 如果不传参事件对象,则事件处理程序2的 event 是上一个事件对象即执行 $('#switcher').trigger('click'); 所在事件处理程序1里的事件对象。若传了事件对象的参数则会将事件处理程序2中的默认传入的 event 覆盖掉成为新的由 trigger() 触发的事件对象(上面的 document 例子)或直接传入由 trigger() 触发的事件对象(事件处理程序2现在没有 event 所以不用覆盖,下面例子):
1 $('#switcher').on('click',function(event){ 2 console.log(event); 3 if($(event.target).is('button')){ 4 var classbody=event.target.id.split('-')[1]; 5 // setBodyClass(classbody); 6 } 7 }) 8 $('#switcher').trigger('click');
这个由 trigger() 触发得来的事件对象是 jQuery.Event() 的实例对象,看到 target 属性正确我就放心了。