trigger和triggerHandler的使用
今天琢磨了好久这个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的使用的更多相关文章
- 【jQuery】【转】jQuery中的trigger和triggerHandler区别
trigger(event, [data]) 在每一个匹配的元素上触发某类事件. 这个函数也会导致浏览器同名的默认行为的执行.比如,如果用trigger()触发一个'submit',则同样会导致浏览器 ...
- JQ中 trigger()和triggerHandler()区别
既然使用了trigger和triggerHandler,那么你应该了解了他们的差别了. trigger():在每一个匹配的元素上触发某类事件. triggerHandler():这个特别的方法将会触发 ...
- Jquery trigger 与 triggerHandler
secying Jquery trigger与triggerHandler trigger: 在每一个匹配的元素上触发某类事件(即触发jQuery对象集合中每一个元素). 这个函数也会导致浏览器同名的 ...
- jquery的trigger和triggerHandler区别
网上关于这个问题都是抄来抄去的,都没怎么说清楚.所以自己做了个测试,供大家参考指教.首先先看API怎么说的 为了检验一下,编写了一个简单的测试代码,如下: <html lang="en ...
- trigger 和 triggerHandler(),自定义事件
trigger 和 triggerHandler(),自定义事件 语法: $(selector).trigger(event,[param1,param2,...]) 1,event 必需.规定指定元 ...
- trigger()和triggerHandler()
trigger()方法触发事件后,还会执行浏览器的默认事件,例如: $('input').trigger("focus); 这一行代码不仅会触发为<input>元素绑定的focu ...
- jQuery中的trigger和triggerhandler区别
$("form :input").blur(function(){ // }).keyup(function(){ $(this).triggerHandler("blu ...
- trigger和triggerhandler的区别
1. trigger会触发默认行为2. trigger会触发所有元素的模拟事件,而triggerHandler只触发一次3. trigger可以链式操作,triggerHandler不能4. trig ...
- 关于jQuery中的trigger和triggerHandler方法的使用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- Redis----windows下的常用命令
1:首先下载redis.从下面地址下:https://github.com/MSOpenTech/redis/releases2:创建redis.conf文件:这是一个配置文件,指定了redis的监听 ...
- Swift中WebView的应用
WebView控件是做网络应用开发中使用最多的控件,直接在WebView内部指定一个网页地址就可以访问网页了,同时也可以实现UIWebViewDelegate协议实现相应的方法去控制内容的加载和处理. ...
- Jmeter系列培训(1)--开山篇
一直以来,我们不断分享,有的人喜欢,也有的人不喜欢,这都没什么,喜欢的点个赞,留个言,不喜欢的就不看好了,今天我们继续,关于jmeter我们分享了很多工作遇到的问题的解决方案,但是很多 ...
- JavaScript学习(二)——深入学习js对象的原型与继承
了解对象 什么是对象? …… 这个就不说了 对象的声明的两种方式 var person = new Object(); person.name="linchen"; pers ...
- https页面证书验证、加密过程简介
1.服务器向CA机构获取证书(假设这个证书伪造不了),当浏览器首次请求服务器的时候,服务器返回证书给浏览器.(证书包含:公钥+申请者与颁发者的相关信息+签名) 2.浏览器得到证书后,开始验证证书的相关 ...
- 负margin
负margin理论: 何谓参考线?参考线就是 margin移动的基准点,此基准点相对于box(自身)是静止的.而margin的数值,就是box相对于参考线的位移量. 一个完整的margin属性是这么写 ...
- 使用Inno Setup Compiler制作安装软件包
前言 项目开发完成之后,需要程序打包发行,本文使用Inno Setup工具制作安装软件包. 系统环境 系统:win7_x64 工具:Inno Setup Complier 实现步骤 1.下载安装Inn ...
- Python3中 sys.argv的用法
sys.avgr 是一个Python的引用模块.刚好做一个作业需要用到它,在sublime上编辑后运行,试图从结果发现它的用途,然而结果一直都是没结果. 后面在网上查了资料,才明白过来.sys.arg ...
- idea_快捷键default&eclipse
关键字: SpringMybatisplusRedisApplicationTests github关键字(springboot拦截器完整项目): implements WebMvcConfigure ...
- 比jsonpath 更方便的json 数据查询JMESPath 使用
类似xml 的xpath json 有jsonpath 都是为了方便进行数据查询,但是jsonpath 的功能 并不是很强大,如果为了方便查询可以使用jmespath. 以下为简单使用: 查询格式 ...