银钻娱乐客服15687949443开户关于bind()函数详解

相信很多接触过jQuery的小伙伴对bind()函数一点都不陌生吧,但是很多小伙伴还不是很清bind()的含义与使用,bind()函数用于为每个匹配元素的一个或多个事件绑定事件处理函数、今天我们就带大家详细介绍下jQuery中关于bind()函数详解!

此外,你还可以额外传递给事件处理函数一些所需的数据。

执行bind()时,事件处理函数会绑定到每个匹配元素上。因此你使用bind()所有button元素绑定了click事件,是为当时文档中存在的每个button元素绑定click事件。如果之后你向文档中添加了新的button元素,绑定事件不会对其生效。如果你希望绑定事件对未来新添加的元素也生效,请使用on()、delegate()、live()等事件函数(尽量优先使用靠前的事件函数)。

此外,你可以为同一元素、同一事件类型绑定多个事件处理函数。触发事件时,jQuery会按照绑定的先后顺序依次执行绑定的事件处理函数。

要删除通过bind()绑定的事件,请使用unbind()函数。

该函数属于jQuery对象(实例)。

语法

bind()函数主要有以下两种形式的用法:

用法一


1

jQueryObject.bind( events [, data ], handler )

用法二:jQuery 1.4.3 新增支持该用法。


1

jQueryObject.bind( events [, data ] [, isDefaultBubble ] )

用法三:jQuery 1.4 新增支持该用法。


1

jQueryObject.bind( eventsMap )

参数

参数 描述
events String类型一个或多个用空格分隔的事件类型和可选的命名空间,例如"click"、"focus click"、"keydown.myPlugin"。
data 可选/任意类型触发事件时,需要通过event.data传递给事件处理函数的任意数据。
handler Function类型指定的事件处理函数。
isDefaultBubble 可选/Boolean类型指定触发事件时,是否允许元素的默认行为和事件冒泡。默认为true
eventsMap Object类型一个Object对象,其每个属性对应事件类型和可选的命名空间(参数events),属性值对应绑定的事件处理函数(参数handler)。

关于参数events中可选的命名空间(1.4.3+才支持),请参考最下面的示例代码。

参数handler中的this指向当前DOM元素。bind()还会为handler传入一个参数:表示当前事件的Event对象。

参数handler的返回值与DOM原生事件的处理函数返回值作用一致。例如submit(表单提交)事件的事件处理函数返回false,可以阻止表单的提交。

参数isDefaultBubble用于指示是否允许元素的默认行为和事件冒泡。如果该值为false,它将阻止元素的默认行为(例如:触发click事件的链接的默认跳转行为,触发submit事件的表单的默认提交行为)和事件的冒泡传递。

返回值

bind()函数的返回值为jQuery类型,返回当前jQuery对象本身。

示例&说明

以点击事件("click")为例,以下是jQuery中事件函数的常规用法(某些函数也存在其它形式的用法,此处暂不列出):


1

<span class="com">// 这里的选择器selector用于指定可以触发事件的元素<span class="pln"><br data-filtered="filtered">// 这里的选择器ancestor应是selector的祖辈元素,selector触发的事件可以被其祖辈元素在事件流中捕获,从而以"委托代理"的形式触发事件。<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// jQuery 1.0+ (1.4.3+支持参数data)<span class="pln"><br data-filtered="filtered">$<span class="pun">(<span class="str">"selector"<span class="pun">).<span class="pln">click<span class="pun">(<span class="pln"> <span class="pun">[<span class="pln"> data <span class="pun">,]<span class="pln"> handler <span class="pun">);<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// jQuery 1.0+ (1.4.3+支持参数data)<span class="pln"><br data-filtered="filtered">$<span class="pun">(<span class="str">"selector"<span class="pun">).<span class="pln">bind<span class="pun">(<span class="pln"> <span class="str">"click"<span class="pln"> <span class="pun">[,<span class="pln"> data <span class="pun">],<span class="pln"> handler <span class="pun">);<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// jQuery 1.3+ (1.4+支持参数data)<span class="pln"><br data-filtered="filtered">$<span class="pun">(<span class="str">"selector"<span class="pun">).<span class="pln">live<span class="pun">(<span class="pln"> <span class="str">"click"<span class="pln"> <span class="pun">[,<span class="pln"> data <span class="pun">],<span class="pln"> handler <span class="pun">);<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// jQuery 1.4.2+<span class="pln"><br data-filtered="filtered">$<span class="pun">(<span class="str">"ancestor"<span class="pun">).<span class="pln">delegate<span class="pun">(<span class="pln"> <span class="str">"selector"<span class="pun">,<span class="pln"> <span class="str">"click"<span class="pln"> <span class="pun">[,<span class="pln"> data <span class="pun">],<span class="pln"> handler <span class="pun">);<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// jQuery 1.7+<span class="pln"><br data-filtered="filtered">$<span class="pun">(<span class="str">"ancestor"<span class="pun">).<span class="pln">on<span class="pun">(<span class="pln"> <span class="str">"click"<span class="pun">,<span class="pln"> <span class="str">"selector"<span class="pln"> <span class="pun">[,<span class="pln"> data <span class="pun">],<span class="pln"> handler <span class="pun">);</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>

请参考下面这段初始HTML代码:


1

<span class="tag"><p<span class="pln"> <span class="atn">id<span class="pun">=<span class="atv">"n1"<span class="tag">><span class="pln"><br data-filtered="filtered">    <span class="tag"><p<span class="pln"> <span class="atn">id<span class="pun">=<span class="atv">"n2"<span class="tag">><span><span class="pln">CodePlayer<span class="tag"></span></p><span class="pln"><br data-filtered="filtered">    <span class="tag"><p<span class="pln"> <span class="atn">id<span class="pun">=<span class="atv">"n3"<span class="tag">><span><span class="pln">专注于编程开发技术分享<span class="tag"></span></p><span class="pln"><br data-filtered="filtered">    <span class="tag"><em<span class="pln"> <span class="atn">id<span class="pun">=<span class="atv">"n4"<span class="tag">><span class="pln">http://www.365mini.com<span class="tag"></em><span class="pln"><br data-filtered="filtered"></p><span class="pln"><br data-filtered="filtered"><p<span class="pln"> <span class="atn">id<span class="pun">=<span class="atv">"n5"<span class="tag">><span class="pln">Google<span class="tag"></p></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>

我们为<p>中的所有<p>元素绑定点击事件:


1

<span class="com">//为p中的所有p元素的click事件绑定事件处理函数<span class="pln"><br data-filtered="filtered">//只有n2、n3可以触发该事件<span class="pln"><br data-filtered="filtered">$<span class="pun">(<span class="str">"p p"<span class="pun">).<span class="pln">bind<span class="pun">(<span class="str">"click"<span class="pun">,<span class="pln"> <span class="kwd">function<span class="pun">(){<span class="pln"><br data-filtered="filtered">// 这里的this指向触发点击事件的p元素(Element)<span class="pln"><br data-filtered="filtered">    alert<span class="pun">(<span class="pln"> $<span class="pun">(<span class="kwd">this<span class="pun">).<span class="pln">text<span class="pun">()<span class="pln"> <span class="pun">);<span class="pln"><br data-filtered="filtered">});</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>

运行代码(以下代码请自行复制到演示页面运行)

此外,我们还可以同时绑定多个事件,并为事件处理函数传递一些附加的数据,我们可以通过jQuery为事件处理函数传入的参数event(Event事件对象)来进行处理:


1

<span class="kwd">var<span class="pln"> obj <span class="pun">=<span class="pln"> <span class="pun">{<span class="pln"> id<span class="pun">:<span class="pln"> <span class="lit">5<span class="pun">,<span class="pln"> name<span class="pun">:<span class="pln"> <span class="str">"王五"<span class="pln"> <span class="pun">};<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">//为n5绑定mouseenter mouseleave两个事件,并为其传入附加数据obj<span class="pln"><br data-filtered="filtered">// 附加数据可以是任意类型<span class="pln"><br data-filtered="filtered">$<span class="pun">(<span class="str">"#n5"<span class="pun">).<span class="pln">bind<span class="pun">(<span class="str">"mouseenter mouseleave"<span class="pun">,<span class="pln"> obj<span class="pun">,<span class="pln"> <span class="kwd">function<span class="pun">(<span class="pln">event<span class="pun">){<span class="pln"><br data-filtered="filtered">    <span class="kwd">var<span class="pln"> $me <span class="pun">=<span class="pln"> $<span class="pun">(<span class="kwd">this<span class="pun">);<span class="pln"><br data-filtered="filtered">    <span class="kwd">var<span class="pln"> obj <span class="pun">=<span class="pln"> event<span class="pun">.<span class="pln">data<span class="pun">;<span class="pln"> <span class="com">// 这就是传入的附加数据<span class="pln"><br data-filtered="filtered">    <span class="kwd">if<span class="pun">(<span class="pln"> event<span class="pun">.<span class="pln">type <span class="pun">==<span class="pln"> <span class="str">"mouseenter"<span class="pun">){<span class="pln"><br data-filtered="filtered">        $me<span class="pun">.<span class="pln">html<span class="pun">(<span class="pln"> <span class="str">"你好,"<span class="pln"> <span class="pun">+<span class="pln"> obj<span class="pun">.<span class="pln">name <span class="pun">+<span class="pln"> <span class="str">"!"<span class="pun">);<span class="pln"><br data-filtered="filtered">    <span class="pun">}<span class="kwd">else<span class="pln"> <span class="kwd">if<span class="pun">(<span class="pln">event<span class="pun">.<span class="pln">type <span class="pun">==<span class="pln"> <span class="str">"mouseleave"<span class="pln"> <span class="pun">){<span class="pln"><br data-filtered="filtered">        $me<span class="pun">.<span class="pln">html<span class="pun">(<span class="pln"> <span class="str">"再见,"<span class="pln"> <span class="pun">+<span class="pln"> obj<span class="pun">.<span class="pln">name <span class="pun">+<span class="pln"> <span class="str">"!"<span class="pun">);<span class="pln">      <br data-filtered="filtered">    <span class="pun">}<span class="pln">           <br data-filtered="filtered"><span class="pun">}<span class="pln"> <span class="pun">);</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>

此外,如果符合条件的元素是bind()函数执行后新添加的,绑定事件不会对其生效。同样以初始HTML代码为例,我们可以编写如下jQuery代码:


1

<span class="com">//为p中的所有p元素的click事件绑定事件处理函数<span class="pln"><br data-filtered="filtered">//只有n2、n3可以触发该事件<span class="pln"><br data-filtered="filtered">$<span class="pun">(<span class="str">"p p"<span class="pun">).<span class="pln">bind<span class="pun">(<span class="str">"click"<span class="pun">,<span class="pln"> <span class="kwd">function<span class="pun">(<span class="pln">event<span class="pun">){<span class="pln"><br data-filtered="filtered">    alert<span class="pun">(<span class="pln"> $<span class="pun">(<span class="kwd">this<span class="pun">).<span class="pln">text<span class="pun">()<span class="pln"> <span class="pun">);<span class="pln"><br data-filtered="filtered">});<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// 新添加的n6不会触发上述click事件<span class="pln"><br data-filtered="filtered">$<span class="pun">(<span class="str">"#n1"<span class="pun">).<span class="pln">append<span class="pun">(<span class="str">‘<p id="n6">上述绑定的click事件不会对该元素也生效!</p>‘<span class="pun">);</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>

参数events还支持为事件类型附加额外的命名空间。当为同一元素绑定多个相同类型的事件处理函数时。使用命名空间,可以在触发事件、移除事件时限定触发或移除的范围。


1

<span class="kwd">function<span class="pln"> clickHandler<span class="pun">(<span class="pln">event<span class="pun">){<span class="pln"><br data-filtered="filtered">    alert<span class="pun">(<span class="pln"> <span class="str">"触发时的命名空间:["<span class="pln"> <span class="pun">+<span class="pln"> event<span class="pun">.<span class="pln">namespace <span class="pun">+<span class="pln"> <span class="str">"]"<span class="pun">);<span class="pln"><br data-filtered="filtered">}<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">var<span class="pln"> $p <span class="pun">=<span class="pln"> $<span class="pun">(<span class="str">"p"<span class="pun">);<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// A:为所有p元素绑定click事件,定义在foo和bar两个命名空间下<span class="pln"><br data-filtered="filtered">$p<span class="pun">.<span class="pln">bind<span class="pun">(<span class="pln"> <span class="str">"click.foo.bar"<span class="pun">,<span class="pln"> clickHandler <span class="pun">);<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// B:为所有p元素绑定click事件,定义在test命名空间下<span class="pln"><br data-filtered="filtered">$p<span class="pun">.<span class="pln">bind<span class="pun">(<span class="pln"> <span class="str">"click.test"<span class="pun">,<span class="pln"> clickHandler <span class="pun">);<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">var<span class="pln"> $n2 <span class="pun">=<span class="pln"> $<span class="pun">(<span class="str">"#n2"<span class="pun">);<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// 触发所有click事件<span class="pln"><br data-filtered="filtered">$n2<span class="pun">.<span class="pln">trigger<span class="pun">(<span class="str">"click"<span class="pun">);<span class="pln"> <span class="com">// 触发A和B (event.namespace = "")<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// 触发定义在foo命名空间下的click事件<span class="pln"><br data-filtered="filtered">$n2<span class="pun">.<span class="pln">trigger<span class="pun">(<span class="str">"click.foo"<span class="pun">);<span class="pln"> <span class="com">// 触发A (event.namespace = "foo")<span class="pln"><br data-filtered="filtered">// 触发定义在bar命名空间下的click事件<span class="pln"><br data-filtered="filtered">$n2<span class="pun">.<span class="pln">trigger<span class="pun">(<span class="str">"click.bar"<span class="pun">);<span class="pln"> <span class="com">// 触发A (event.namespace = "bar")<span class="pln"><br data-filtered="filtered">// 触发同时定义在foo和bar两个命名空间下的click事件<span class="pln"><br data-filtered="filtered">$n2<span class="pun">.<span class="pln">trigger<span class="pun">(<span class="str">"click.foo.bar"<span class="pun">);<span class="pln"> <span class="com">// 触发A (event.namespace = "bar.foo")<span class="pln"><br data-filtered="filtered"><br data-filtered="filtered">// 触发定义在test命名空间下的click事件<span class="pln"><br data-filtered="filtered">$n2<span class="pun">.<span class="pln">trigger<span class="pun">(<span class="str">"click.test"<span class="pun">);<span class="pln"> <span class="com">// 触发B (event.namespace = "test")</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>

bind()函数的参数eventsMap是一个对象,可以"属性-值"的方式指定多个"事件类型-处理函数"。对应的示例代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

var eventsMap = {

    "mouseenter": function(event){

        $(this).html( "Hello!");       

    },

    

    "mouseleave": function(event){

        $(this).html( "Bye!");

    }

};

//为n5绑定mouseenter mouseleave两个事件

$("#n5").bind( eventsMap );

总结:

本文使用示例代码详细的为大家分析了jQuery中关于bind()函数,相信大家对此也是有了进一步的了解,希望对你的工作有所帮助!

原文地址:https://www.cnblogs.com/dfsdfgdfg/p/10490991.html

时间: 2024-10-25 02:27:57

银钻娱乐客服15687949443开户关于bind()函数详解的相关文章

银钻娱乐客服15687949443关于小程序常见问题,看完你就是老司机

怎么开通小程序?怎么注册小程序名称呢......云指在运营的过程中,收到了很多朋友类似这样的问题反馈.今天为大家送上贴心的100个关于小程序Q&A,帮助大家把所有问题一扫而光,看完你就是老司机了. 1.Q:微信支付主体需要和小程序主体一致吗? A:必须是主体一致的 2.Q:一般微信支付开通需要多久? A:1-5个工作日 3.Q:微信支付商户填写结算账户找不到开户银行的处理方法 A:微信支付商户申请填写结算账户时如果找不到所在的银行,请选择“其他银行”后手动填写所在支行全称,例如:建设银行佛山市环

关于银钻娱乐客服15687949443微信小程序

小程序越来越热,唱衰小程序的声音也逐步消退,每隔一百米至少有一个小程序的趋势已是无可阻拦.以肯德基.星巴克.农业银行.摩拜单车等为首的大企业纷纷挑选开发归于自己的小程序,也是因为看准了小程序的诸多优点.不过因为小程序的第一次发布会间隔现在也曩昔一年半的时刻,小程序曝光初期的体现也并不亮眼,导致仍是会有人不太了解小程序,也不清楚小程序能做什么.要怎样开发.多久能开发好.要怎样运用等.大家的好朋友上线君,今日就为大家深度解读一下,究竟什么是微信小程序.本文绝对干货,较长,第一次阅览大约需求 15-2

银钻娱乐客服15687949443浅谈社交软件

提起中国的社交软件,比较厉害的两个那就应该是QQ与微信.这两个产品可是腾讯的摇钱树,聚宝盆.归结其原因,也就是居高不下的活跃用户量了.现在各种外卖APP,打车APP,购物APP等疯狂补贴用户,不都是为了用户量和市场占有率吗! 今天要说的就是QQ与微信这两款社交软件.曾在15年11月份的时候看到过一条新闻,说的是微信的月活跃用户量6.5亿,同比增长百分之三十九,超越移动QQ.期间竟然还有人说,微信必将取代移动QQ.我想了想后,却很不以为然,因为数据只是数据,你要根据数据去理智的进行分析判断. 首先

银钻娱乐客服15687949443编程新手快来看!

我们要学习的编程语言是C++,因为自1998年起大学先修课程考试就基于C++语言了.之前的考试用的是Pascal语言.C++和Pascal都是高级语言,你或许也听说过Java.C和Fortran等其他高级语言吧.从“高级语言”这个名字可以推断,应该同样存在低级语言,低级语言一般也称为机器语言或汇编语言.不严格地讲,计算机只能执行低级语言编写的程序.正因如此,高级语言编写的程序需要经过翻译才能运行. 首先,使用高级语言编程要容易得多,“容易”意味着编程时间更少,代码更简短易读,出错的可能性更小.其

银钻娱乐客服15687949443史上最全的小程序文章

2017年1月9日,张小龙关于小程序的承诺最终成为了现实. 然后,我们的朋友圈就被这些文章刷爆了: < 你好,我是小程序 >. < 体验了下微信小程序,感受到了腾讯的野心 >. < 怎样激活微信小程序 >. 有人开始欢呼,称这是一个新的时代的到来.而有人也开始悲戚,称这也是过去一个时代的终结.那究竟小程序有何种魅力,能让人们这么悲喜交加呢? 很遗憾,自己未能在凌晨就将这篇文章写完,但我依旧相信这篇文章能让大家所有收获,从而对微信小程序有个更清晰的认知. 文章将从六个方面

银钻娱乐客服15687949443关于小程序,我只服这篇文章

为什么选择小程序,而不是公众号或App? 微信小程序能实现的事务,App理论上都能实现:但App能实现的功能,微信小程序却受限于框架与微信开放的API,就不一定能做. 微信小程序.微信及App应用的关系如图所示. 小程序还有一个极其重要的场景,即作为App前期开发的一种思路验证.或者将App的某个常用功能模块实现为小程序,也可以为App引流. 但小程序不可能完全替代App,主要原因有: 小程序作为微信内场景,如同阅读文章一样,同样会遇到使用小程序和聊天之间的矛盾,这注定了小程序不能做很重很长时间

程序员学银钻娱乐客服15687949443习提高必看的一篇文章

作为程序员我们应该知道什么,这是很重要的.不知不觉做软件现已做了十年,有成功的高兴,也有失利的苦楚,但总不敢称自己是高手,由于和我心目中真实的高手们比起来,还差的太远.世界上并没有成为高手的捷径,但一些基本原则是能够遵从的. 1. 厚实的根底. 数据结构.离散数学.编译原理,这些是一切计算机科学的根底,如果不把握他们,很难写出高水平的程序.据我的调查,学计算机专业的人比学其他专业的 人更能写出高质量的软件.程序人人都会写,但当你发现写到必定程度很难再提高的时分,就应该想想是不是要回过头来学学这些

银钻国际客服17387699997追忆张国荣上海的足迹

张国荣(1956年9月12日-2003年4月1日)生于香港,是一位在全球华人社会和亚洲地区具有影响力的著名歌手.演员和音乐人;大中华区乐坛和影坛巨星;演艺圈多栖发展最成功的代表之一.他通晓词曲创作,曾担任过MTV导演.唱片监制.电影编剧.电影监制.张国荣是香港乐坛的殿堂级歌手之一,曾获得香港乐坛最高荣誉金针奖;他是第一位享誉韩国乐坛的华人歌手,亦是华语唱片在韩国销量纪录保持者.他于1991年当选香港电影金像奖影帝;1993年主演的影片<霸王别姬>打破中国内地文艺片在美国的票房纪录,他亦凭此片蜚

银钻娱乐开户17387699997迷失的女孩

小孩一个人在大街上玩,不知不觉迷失了方向,怎么回不到家,便大声哭起来.警察过来说:"好孩子,你哭什么,回家去吧!"小女孩哭着说:"我迷路了,找不到家." "你家在什么地方?"警察问. "在楼上."小女孩说. "你爸爸叫什么?" "亲爱的!" "你妈妈叫什么?" "宝贝!" "你家里还有谁?" "还有我." &