当前位置: 首页 > news >正文

app外包开发公司平台专注苏州网站优化

app外包开发公司平台,专注苏州网站优化,网站设计ps做效果图过程,做网站如何自己寻找客户转载自 jQuery的三种bind/One/Live/On事件绑定使用方法 jQuery是 一款优秀的JavaScript框架,在旧版里主要用bind()方法#xff0c;在新版里又多了两种One(),Live()#xff0c;下面介绍这几种方法的使用 本篇文章介绍了#xff0c;关于jQuery新的事件绑定机制on()的使用技…转载自   jQuery的三种bind/One/Live/On事件绑定使用方法 jQuery是 一款优秀的JavaScript框架,在旧版里主要用bind()方法在新版里又多了两种One(),Live()下面介绍这几种方法的使用 本篇文章介绍了关于jQuery新的事件绑定机制on()的使用技巧。需要的朋友参考下  今天浏览jQuery的deprecated列表发现live()和die()在里面了赶紧看了一下发现从jQuery1.7开始jQuery引入了全新的事件绑定机制on()和off()两个函数统一处理事件绑定。因为在此之前有bind(),  live(), delegate()等方法来处理事件绑定jQuery从性能优化以及方式统一方面考虑决定推出新的函数来统一事件绑定方法并且替换掉以前的方法。 on(events,[selector],[data],fn) events:一个或多个用空格分隔的事件类型和可选的命名空间如click或keydown.myPlugin 。 selector:一个选择器字符串用于过滤器的触发事件的选择器元素的后代。如果选择器为null或省略当它到达选定的元素事件总是触发。 data:当一个事件被触发时要传递event.data给事件处理函数。 fn:该事件被触发时执行的函数。 false 值也可以做一个函数的简写返回false。 替换bind() 当第二个参数selector为null时on()和bind()其实在用法上基本上没有任何区别了所以我们可以认为on()只是比bind()多了一个可选的selector参数所以on()可以非常方便的换掉bind() 替换live() 在1.4之前相信大家非常喜欢使用live(),因为它可以把事件绑定到当前以及以后添加的元素上面当然在1.4之后delegate()也可以做类似的事情了。live()的原理很简单它是通过document进行事件委派的因此我们也可以使用on()通过将事件绑定到document来达到live()一样的效果。 live()写法 $(#list li).live(click, #list li, function() {//function code here. }); on()写法 $(document).on(click, #list li, function() {//function code here. }); 这里的关键就是第二个参数selector在起作用了。它是一个过滤器的作用只有被选中元素的后代元素才会触发事件。 替换delegate() delegate()是1.4引入的目的是通过祖先元素来代理委派后代元素的事件绑定问题某种程度上和live()优点相似。只不过live()是通过document元素委派而delegate则可以是任意的祖先节点。使用on()实现代理的写法和delegate()基本一致。 delegate()的写法 $(#list).delegate(li, click, function() {//function code here. }); on()写法 $(#list).on(click, li, function() {//function code here. }); 貌似第一个和第二个参数的顺序颠倒了一下别的基本一样。 总结 jQuery推出on()的目的有2个一是为了统一接口二是为了提高性能所以从现在开始用on()替换bind(),  live(),  delegate吧。尤其是不要再用live()了因为它已经处于不推荐使用列表了随时会被干掉。如果只绑定一次事件那接着用one()吧这个没有变化。 jQuery是 一款优秀的JavaScript框架,在旧版里主要用bind()方法在新版里又多了两种One(),Live()下面介绍这几种方法的使用 1. bind/Unbind 在jquery的事件模型中有两个基本的事件绑 定函数bind与unbind这两个函数的含义就是匹配页面元素进行相关事件的处理。比如我们在JS中经常使用到的 onfocusonbluronmouseoveronmousedown等事件都可以作为bind的参数进行传递。 $(#id).bind(click,function(){alert(tt!)}); 其中bind的第一个参数代表的含义是事件类型(注意不需要加on)function中的代码就是你要执行的逻辑 代码 多个事件绑定bind还允许你绑定多个事件事件名字之间用空格隔开例如 $(a).bind(click mouseover,function(){ 在最新的jquery1.4版本中对bind方法进行了改进你可以在bind方法传入一个类JSON对象来一次绑定多 个事件处理函数。 $(a).bind({ click:function(){alert(a);}, mouseover:function(){alert(a again!)} 在function函数中你还可以通过传递一个javaScript对 象给function方法这个事件对象通常是可以省略的。 bind中还有一个参数data 该参数一般情况下很少使用通常为了解决在同一个方法中处理同一个变量时有很好的处理。 var productnameSports Shoes; $(#Area).bind(click,function(){ alert(productname); }); productnamenecklace, $(#Area).bind(click,function(){ alert(productname); }); 由于变量productname被重新赋值所以输出的消息都是”necklace”,这里不了解可以去查阅下关于JavaScript的变量作用域,要 解决这个问题就必须使用到data参数 var productnameSports Shoes; $(#Area).bind(click,{pn:productname},function(){ alert(event.data.pn); }); productnamenecklace, $(#Area).bind(click,{pn:productname},function(){ alert(event.data.pn); }); 2. One 为每一个匹配元素的特定事件像click绑定一个一次性的事件处理函数。该方法与bind方法的参数一样与bind方法的区别就是只对匹配元素的事 件处理执行一次执行完之后以后再也不会执行,当然重新发起web请求时它又会执行一次。 $(a).one(click,function(){ alert(a); }) 单击页面上的a元素后弹出消息除非用户发起第二次请求否则再次点击a元素不会弹出消息对话框。 3. live 该方法主要是能处理动态添加的元素给那些后添加的元素也一样绑定事件。 $(a).live(click,function(){ alert(show message!); }) 然后如果我添加一个元素 $(body).appnend(Another Element); 那么该元素也会被触发事件处理函数alert。 另外jQuery还提供了一些绑定这些标准事件类型的简单方式比如.click()用于简化.bind(‘click)。 一共有以下这些事件名称blur, focus, focusin, focusout, load, resize, scroll, unload, click, dblclick, mousedown, mouseup, mousemove, mouseover, mouseout, mouseenter, mouseleave, change, select, submit, keydown, keypress, keyup, error 等。 下面看下jQuery中绑定事件bind() on() live() one()的异同 jQuery中绑定事件的四种方法他们可以同时绑定一个或多个事件 bind()-------------------------版本号小于3.0在Jquery3.0中已经移除相应unbind()也移除 live()--------------------------版本号小于1.7在Jquery1.7中已经移除相应die()也移除 delegate()-------------------版本号小于1.7在Jquery1.7中已经移除 on()---------------------------版本号大于1.7在Jquery1.7中添加相应off()也添加 Abind()事件的用法 title绑定事件/titlescript srcjs/jQuery1.11.1.js typetext/javascript/scriptscript$(function () {$(p).bind({mouseover: function () {$(p).css(background-color, red);},mouseout: function () {$(p).css(background-color, );}});});/script /head bodypwhat are you doing?/p /body /html 第一个最大的区别就是bind()的事件绑定是只对当前页面选中的元素有效。如果你想对动态创建的元素bind()事件是没有办法达到效果的。 在后面的动态生成DOM元素绑定事件就要使用on();
http://www.pierceye.com/news/652528/

相关文章:

  • 免费微网站建设地图标注收费属于违法行为吗
  • 网站开发工程师php岗位职责企业网站案例展示
  • 青岛网站营销推广网站工作室设计
  • 网站可以增加关键词吗做网站也是一门技术
  • 长沙 外贸网站建设公司排名传统文化传播公司网站建设
  • 站群seo技巧1 企业网站的一般内容是什么
  • 广东省城乡建设厅投诉网站首页wordpress posts
  • 泰安建设厅网站怎样给公司做一个网站
  • 扶贫网站开发的目的是什么2023年舆情分析报告
  • 河南建设银行处理违章网站网站做支付需要准备什么东西吗
  • 网站设置不能通过链接访问比较好的源码网站
  • 深圳做网站联雅空间业务建设网站
  • 合肥企业网站设计制作莱芜杂谈 莱芜话题
  • 大圣网站建设为什么不推荐大家去外包公司
  • 做网站手机版wordpress如何换成经典编辑器
  • 建设网站的知识企业做网站设计的
  • 西安网站排名分析软文营销把什么放在第一位
  • 织梦手机网站模板删除不了宁波网站建设服务商
  • 深圳网站建设最专业网站seo技术
  • 定制网站开发一般多少钱郑州哪家公司做网站好
  • jsp做的网站效果给你一个网站你怎么做的吗
  • 怎样做网站海报wordpress最近怎么又是5.0更新
  • 淡水网站建设哪家便宜设计网页分析
  • 长沙多迪php网站开发培训学校小说榜单首页百度搜索风云榜
  • 门户网站建设计入什么科目网站备案 时间更新
  • 企业建网站租用服务器好还是买一个好wordpress 预订插件
  • 电气建设网站下载的asp网站怎么打开
  • 南阳网站建设icp备手机应用商店免费下载
  • 网站开发测量像素工具网站模板包含哪些内容
  • 南昌网站排名优化费用湖北公众号定制开发