今天琢磨了好久这个trigger和triggerHandler的用法.在网上搜了好多,不过大都是相互抄袭,毛意思都没有.后来自己做了研究.

trigger:

1.可以用来触发事件.

 <input id="guoyansi" value="单击" type="button" />
  $(function(){
$("#guoyansi").click(function(){
alert("点我干嘛");
});
//下面的两种情况都可以在页面加载完毕后自动触发
$("#guoyansi").click();
$("#guoyansi").trigger("click"); })

2.可以用来传递参数trigger(typeEvent[,data]);

  <input id="guoyansi" value="单击" type="button" />
  $(function(){
$("#guoyansi").click(function(e,text){
text=text||"我是click触发的";
alert(text);
});
$("#guoyansi").trigger("click",["我是trigger触发的"]); })

3.传递多个参数:

 <input id="guoyansi" value="单击" type="button" />
 $(function(){
$("#guoyansi").click(function(e,m1,m2,m3){
var text="";
if(m1||m2||m3) text=m1+","+m2+","+m3;
else text="我是click触发的";
alert(text);
});
$("#guoyansi").trigger("click",["m1","m2","m3"]); })

4.自定义事件.

  <input id="guoyansi" value="单击" type="button" />
<input type="text" id="guoTxt"/>
 $(function(){
$("#guoTxt").on("myEvent",function(){//给guoTxt自定义一个myEvent事件
alert($(this).val());
});
$("#guoyansi").click(function(){//单击guoyansi按钮时,触发我们的自定义事件
$("#guoTxt").trigger("myEvent");
});
})

5.triggerHandler()的方法在作用上类似于trigger(),但是是有一定的区别的.

  1.triggerHandler方法不会引起浏览器默认的行为,而仅仅是执行绑定到focus事件的处理程序.

 <input type="button" id="guo" value="trigger"/>
<button type="button" id="yan"value="triggerHandler"/>
<input id="si" type="text" />
  $(function(){
$("#guo").bind("click",function(){
$("#si").trigger("focus",["trigger"]);
});
$("#yan").bind("click",function(){
$("#si").triggerHandler("focus",["triggerHandler"]);
});
$("#si").bind("focus",function(e,handler){
if(typeof(handler)=="undefined") handler="用户操作";
$(this).val(handler);
});
})

用谷歌浏览器测试,效果更明显.

单击文本框:

文本框中有光标,并且还有橙色边框.

单击trigger:

效果和单击文本框是一样的.

单击triggerHandler:

只是执行了focus的事件,文本框中没有光标,并且边框也没有变颜色.

  2.trigger()对匹配到的所有元素进行操作,triggerHandler()只对第一个元素做处理.

 <input type="button" id="guo" value="trigger"/>
<input type="button" id="yan" value="triggerHandler"/>
<input class="si" type="text" />
<input class="si" type="text" />
<input class="si" type="text" />
<input class="si" type="text" />
 $(function(){
$("#guo").bind("click",function(){
$(".si").trigger("focus",["trigger"]);
});
$("#yan").bind("click",function(){
$(".si").triggerHandler("focus",["triggerHandler"]);
});
$(".si").bind("focus",function(e,handler){
if(typeof(handler)=="undefined") handler="用户操作";
$(this).val(handler);
});
})

单击trigger按钮:

单击triggerHandler按钮:

3:triggerHandler()方法不会发生冒泡,如果这些事件不被目标元素直接处理,则它什么事情都不做.

<input type="button" id="guo" value="trigger"/>
<input type="button" id="yan" value="triggerHandler"/>
<div class="father" style="width:200px; height:200px; background-color:black;">
<div class="children" style="width:100px; height:100px; background-color:red;"></div>
</div>

 $(function(){
$("#guo").bind("click",function(){
$(".children").trigger("click");
});
$("#yan").bind("click",function(){
$(".children").triggerHandler("click");
});
$(".father").click(function(){
alert("你单击了父div");
});
$(".children").click(function(){
alert("你单击了子div");
});
})

因为冒泡,单击了trigger按钮后,会弹出2个弹出框;因为不冒泡单击triggerHandler按钮,只会出现一个"你单击了子div"的弹出框.

3.triggerHandler()不返回jQuery对象,而是返回有这个方法的最后一个处理程序的返回值.如果没有返回值,则默认是undefined.

 <input type="button" id="guo" value="trigger"/>
<input type="button" id="yan" value="triggerHandler"/>
<div class="father" style="width:200px; height:200px; background-color:black;">
<div class="children" style="width:100px; height:100px; background-color:red;"></div>
</div>

 $(function(){
$("#guo").bind("click",function(){
$(".children").trigger("click").css("background-color","blue");
});
$("#yan").bind("click",function(){
var a=$(".children").triggerHandler("click");
alert(a);
});
$(".father").click(function(){
alert("你单击了父div");
});
$(".children").click(function(){
alert("你单击了子div");
return "我来自triggerHandler的返回值";
});
})

单击trigger后,红色会变成蓝色:

单击triggerHandler,会有返回值.

trigger和triggerHandler的使用的更多相关文章

  1. 【jQuery】【转】jQuery中的trigger和triggerHandler区别

    trigger(event, [data]) 在每一个匹配的元素上触发某类事件. 这个函数也会导致浏览器同名的默认行为的执行.比如,如果用trigger()触发一个'submit',则同样会导致浏览器 ...

  2. JQ中 trigger()和triggerHandler()区别

    既然使用了trigger和triggerHandler,那么你应该了解了他们的差别了. trigger():在每一个匹配的元素上触发某类事件. triggerHandler():这个特别的方法将会触发 ...

  3. Jquery trigger 与 triggerHandler

    secying Jquery trigger与triggerHandler trigger: 在每一个匹配的元素上触发某类事件(即触发jQuery对象集合中每一个元素). 这个函数也会导致浏览器同名的 ...

  4. jquery的trigger和triggerHandler区别

    网上关于这个问题都是抄来抄去的,都没怎么说清楚.所以自己做了个测试,供大家参考指教.首先先看API怎么说的 为了检验一下,编写了一个简单的测试代码,如下: <html lang="en ...

  5. trigger 和 triggerHandler(),自定义事件

    trigger 和 triggerHandler(),自定义事件 语法: $(selector).trigger(event,[param1,param2,...]) 1,event 必需.规定指定元 ...

  6. trigger()和triggerHandler()

    trigger()方法触发事件后,还会执行浏览器的默认事件,例如: $('input').trigger("focus); 这一行代码不仅会触发为<input>元素绑定的focu ...

  7. jQuery中的trigger和triggerhandler区别

    $("form :input").blur(function(){ // }).keyup(function(){ $(this).triggerHandler("blu ...

  8. trigger和triggerhandler的区别

    1. trigger会触发默认行为2. trigger会触发所有元素的模拟事件,而triggerHandler只触发一次3. trigger可以链式操作,triggerHandler不能4. trig ...

  9. 关于jQuery中的trigger和triggerHandler方法的使用

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. 配置ssh互信的一个小问题记录

    在我们安装集群软件时,经常需要配置机器之间的互信,每个人也有一套自己熟悉的方法. 但是在今天配置互信过程中,发现操作过程还是一样,但是就是不能互信,通过查找资料解决了,做一下记录. 我经常使用的方式: ...

  2. 序列化 NSKeyedArchiver,NSPropertyListSerialization

    到目前为止,看到oc实现的序列化方式有两种:NSKeyedArchiver,NSPropertyListSerialization. 在这两种序列化方式中,NSData都是序列化的目标.两种方式的不同 ...

  3. 深度分析:Android4.3下MMS发送到附件为音频文件(音频为系统内置音频)的彩信给自己,添加音频-发送彩信-接收彩信-下载音频附件-预览-播放(三,接收彩信<2,下载彩信>)

    彩信的接收简介: 主要是由应用程序负责从彩信服务中心(MMSC Multimedia Messaging Service Center)下载彩信信息.大致的流程是Frameworks会先发出一条短信, ...

  4. HTTP Header之Content-Type

    HTTP Header之Content-Type   目录 1. HTTP Header 2. 文件请求和接口请求 3. 几种 Content-Type 3.1 application/x-www-f ...

  5. 题目1003:A+B

    题目1003:A+B 时间限制:1 秒内存限制:32 兆 题目描述: 给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号","隔开. 现在请计算A+B的结果,并以正常形式 ...

  6. Windows Phone 8, 添加Map控件

    摘要: 1. 添加Map控件到程序. 2. 在Map控件中显示您当前的位置. 内容: 首先在WMAppManifest.xml中的Capabilities选项卡中勾选如下两项:ID_CAP_MAP, ...

  7. iPhone/iPad被停用怎么办 3招轻松解锁

    家中小孩玩电脑游戏,自己拿了iPad,随便输入密码,结果造成平板电脑无法使用,相信这是许多家长都将面对或是早已发生的事情.本文整理当iPhone或是iPad被停用时的处理方法. iPhone被停用 为 ...

  8. bootstrap中如何控制input的宽度

    ☆1☆ bootstrap中如何控制input的宽度: v2版本:定义了很多class,可用在input. "input-block-level"."input-mini ...

  9. PipelineDB 1.0.0 发布——使用标准的pg 扩展开发模型

    PipelineDB 1.0.0 发布已经发布了,现在的已经成为一个标准的pg 扩展了,语法也有变动 create continous view 修改为了view,create streaem 修改为 ...

  10. 详解SID之终结篇

    今天测试某款监控软件时遇到一个比较棘手的问题,这款软件需要在被监控端安装客户端程序.成功在第一个节点安装好客户端后问题出现了,在其他节点安装时报错无法安装.软件报的错误信息无从下手且系统日志也看不出什 ...