iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >jquery绑定事件的作用是什么
  • 708
分享到

jquery绑定事件的作用是什么

2023-07-05 14:07:46 708人浏览 独家记忆
摘要

本篇内容介绍了“Jquery绑定事件的作用是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!jquery绑定事件的作用:将普通的事件eve

本篇内容介绍了“Jquery绑定事件的作用是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

jquery绑定事件的作用:将普通的事件event绑定在DOM节点上,当DOM节点被选中时,将事件与之绑定,方便用户提供相应的操作。jQuery中提供了四种事件绑定方式,分别是bind、live、delegate、on,对应的解除监听的函数分别是unbind、die、undelegate、off。

什么是事件?

页面对不同访问者的响应叫做事件。

事件处理程序指的是当 html 中发生某些事件时所调用的方法。

实例:

  • 在元素上移动鼠标。

  • 选取单选按钮

  • 点击元素

在事件中经常使用术语"触发"(或"激发")例如: "当您按下按键时触发 keypress 事件"。

jquery的事件绑定

通常,我们是需要对具体的节点的相关事件作处理,比如一个按钮被点击了之类的。但这里有一个问题,如果我们能获取到具体的节点,当然没什么说的。不过有时,我们要处理的节点却还没有存在,但是我们又要预定义它的事件处理。比如,我们说在一个 UL 中,每一个 LI 被点击时,都要执行一个函数。但是, UL 中的内容本身可能是变化的,开始时它只有两个 LI ,之后又变成了三个 LI ,多出的那一个 LI 也要能响应事件才行。

上述的情况是一个普遍的需求。我们可以利用事件的冒泡机制来实现目的。我们把事件处理绑定在 UL 上,这样,当 LI 被点击时,会冒泡到上级的 UL ,这样在处理事件时就可以判断出具体是哪个节点的事件,以便作下一步处理。

事件绑定就是针对dom元素的事件,绑定在dom元素上,可以在一个元素上监听同一事件多次。作用:将普通的事件 event 绑定在 DOM 节点上,当 DOM 节点被选中时,将事件与之绑定,方便用户提供相应的操作。

jQuery中提供了四种事件绑定方式,分别是bind、live、delegate、on,对应的解除监听的函数分别是unbind、die、undelegate、off。

这几种方式之间的区别:

bind()函数只能针对已经存在的元素进行事件的设置;但是live(),on(),delegate()均支持未来新添加元素的事件设置;

bind()函数在jquery1.7版本以前比较受推崇,1.7版本出来之后,官方已经不推荐用bind(),替代函数为on(),这也是1.7版本新添加的函数,同样,可以用来代替live()函数,live()函数在1.9版本已经删除;

live()函数和delegate()函数两者类似,但是live()函数在执行速度,灵活性和CSS选择器支持方面较delegate()差些

bind()支持Jquery所有版本;live()支持jquery1.9-;delegate()支持jquery1.4.2+;on()支持jquery1.7+;

下面详细介绍一下这几种方式:

1、bind(type,[data],function(eventObject))

bind是使用频率较高的一种,作用就是在选择到的元素上绑定特定事件类型的监听函数,参数的含义如下:

type:事件类型,如click、change、mouseover等;

data:传入监听函数的参数,通过event.data取到。可选;

function:监听函数,可传入event对象,这里的event是jQuery封装的event对象,与原生的event对象有区别,使用时需要注意

bind的源码

  bind: function( types, data, fn ) {  return this.on( types, null, data, fn );  }$('#myol li').bind('click',getHtml);

bind的特点就是会把监听器绑定到目标元素上,有一个绑一个,在页面上的元素不会动态添加的时候使用它没什么问题。但如果列表中动态增加一个“列表元素5”,点击它是没有反应的,必须再bind一次才行。要想不这么麻烦,我们可以使用live。

jQuery还有一种事件绑定的简写方式如a.click(function(){});、a.change(function(){});等,它们的作用与bind一样,仅仅是简写而已。

2、live(type, [data], fn)

live的参数和bind一样,它又有什么蹊跷呢,我们还是先瞄一眼源码:

live: function( types, data, fn ) {jQuery( this.context ).on( types, this.selector, data, fn );return this;}

可以看到live方法并没有将监听器绑定到自己(this)身上,而是绑定到了this.context上了。这个context是什么东西呢?其实就是元素的限定范围,看了下面的代码就清楚了:

$('#myol li').context; //document$('#myol li','#myol').context; //document$('#myol li',$('#myol')[0]); //ol

通常情况下,我们都不会像第三种方式那样使用选择器,所以也就认为这个context通常就是document了,即live方法把监听器绑定到了 document上了。不把监听器直接绑定在元素上,你是不是想起事件委托机制来了呢?若没有,可以点击这里回忆一下。live正是利用了事件委托机制来 完成事件的监听处理,把节点的处理委托给了document。在监听函数中,我们可以用event.currentTarget来获取到当前捕捉到事件的 节点。下面的例子来揭晓:

$('#myol li').live('click',getHtml);

3、delegate和on

live存在那样的缺点,所以我们就思考,既然老爷子负担那么重,可不可以别把监听器绑定在document上呢,绑定在就近的父级元素上不就好了。顺应正常逻辑,delegate诞生了。

参数多了一个selector,用来指定触发事件的目标元素,监听器将被绑定在调用此方法的元素上。看看源码:

delegate: function( selector, types, data, fn ) {return this.on( types, selector, data, fn );}

又是调用了on,并且把selector传给了on。看来这个on真的是举足轻重的东西。照样先不管它。看看示例先:

$('#myol').delegate('li','click',getHtml);

看了这么多,你是不是迫不及待想看看这个on的真实面目了呢,这就来:

on(type,[selector],[data],fn)

参数与delegate差不多但还是有细微的差别,首先type与selector换位置了,其次selector变为了可选项。交换位置的原因不好查证,应该是为了让视觉上更舒服一些吧。

我们先不传selector来看一个例子:

$('#myol li').on('click',getHtml);

可以看到event.currentTarget是li自己,与bind的效果一样。至于传selector进去,就是跟delegate一样的意义了,除了参数顺序不同,其他完全一样。

终于看到on的真实作用了,那么,这么多的事件绑定方式,我们该如何进行选择呢?

其实这个问题是完全不必纠结的,因为你已经知道他们之间的区别了不是么?根据实际情况斟酌使用就行。不过官方有一个推荐就是尽量使用on,因为其他 方法都是内部调用on来完成的,直接使用on可以提高效率,而且你完全可以用on来代替其他三种写法。至于如何代替我想就不必这么直白的写出来了,真正理 解它们的区别之后自然而然也就不是难事了。

“jquery绑定事件的作用是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: jquery绑定事件的作用是什么

本文链接: https://www.lsjlt.com/news/352129.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • jquery绑定事件的作用是什么
    本篇内容介绍了“jquery绑定事件的作用是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!jquery绑定事件的作用:将普通的事件eve...
    99+
    2023-07-05
  • jquery绑定事件有什么作用
    本教程操作环境:windows7系统、jquery3.6版本、Dell G3电脑。什么是事件?页面对不同访问者的响应叫做事件。事件处理程序指的是当 HTML 中发生某些事件时所调用的方法。实例:在元素上移动鼠标。选取单选按钮点击元素在事件中...
    99+
    2023-05-14
    jquery 事件绑定
  • jquery绑定事件指的是什么
    本篇文章和大家了解一下jquery绑定事件指的是什么。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 在jquery中,绑定事件的意思是将普通的时间event绑...
    99+
    2024-04-02
  • jQuery中on绑定的事件怎么解绑
    这篇文章主要介绍了jQuery中on绑定的事件怎么解绑的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇jQuery中on绑定的事件怎么解绑文章都会有所收获,下面我们一起来看看吧。解绑单个事件在jQuery中,我们...
    99+
    2023-07-05
  • jquery事件如何绑定
    本文小编为大家详细介绍“jquery事件如何绑定”,内容详细,步骤清晰,细节处理妥当,希望这篇“jquery事件如何绑定”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、bind()bing()用来绑定事件,例如...
    99+
    2023-06-29
  • jquery如何绑定事件
    jquery中绑定事件的方法有:1.使用on()函数绑定事件;2.使用bind()函数绑定事件;3.使用live()函数绑定事件;4.使用delegate()函数绑定事件;jquery中绑定事件的方法有以下几种使用on()函数绑定事件$(&...
    99+
    2024-04-02
  • jquery怎么绑定事件调用函数
    这篇文章主要讲解了“jquery怎么绑定事件调用函数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“jquery怎么绑定事件调用函数”吧! ...
    99+
    2024-04-02
  • jQuery如何绑定enter事件
    这篇文章主要为大家展示了“jQuery如何绑定enter事件”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“jQuery如何绑定enter事件”这篇文章吧。&nb...
    99+
    2024-04-02
  • javascript绑定事件的方法是什么
    本篇内容介绍了“javascript绑定事件的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!绑定...
    99+
    2024-04-02
  • jQuery如何绑定鼠标事件?
    这篇文章将为大家详细讲解有关jQuery如何绑定鼠标事件?,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 通过jQuery绑定鼠标事件 jQuery提供了多种方法来绑定鼠标事件,包括: $(selec...
    99+
    2024-04-02
  • jQuery如何绑定键盘事件?
    这篇文章将为大家详细讲解有关jQuery如何绑定键盘事件?,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。jQuery绑定键盘事件 导言 jQuery提供了一种简便的方法来绑定键盘事件,允许开发者在用户按下...
    99+
    2024-04-02
  • jquery事件绑定方法介绍
    一、bind() bing()用来绑定事件,例如: 二、unbind() unbind()用来解除事件的绑定。例如: 三、on() on()方法用来绑定事件,例如: 四、off...
    99+
    2024-04-02
  • jQuery如何绑定多个事件?
    ...
    99+
    2024-04-02
  • jquery如何绑定悬浮事件
    在jquery中使用mouseover()方法绑定悬浮事件:1.新建html项目,引入jquery;2.创建div标签,设置id属性;3.通过id获取标签对象,使用mouseover()方法绑定鼠标悬浮事件;4.使用css()方法设置鼠标悬...
    99+
    2024-04-02
  • jQuery如何绑定滚动事件?
    这篇文章将为大家详细讲解有关jQuery如何绑定滚动事件?,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。jQuery绑定滚动事件 jQuery提供了一个简便的方法来绑定滚动事件,允许您在滚动页面或特定元素...
    99+
    2024-04-02
  • jQuery中bind/One/Live/On事件绑定怎么用
    这篇文章主要介绍了jQuery中bind/One/Live/On事件绑定怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。浏览jQuery...
    99+
    2024-04-02
  • jquery如何取消on()绑定的事件
    这篇文章主要讲解了“jquery如何取消on()绑定的事件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“jquery如何取消on()绑定的事件”吧! ...
    99+
    2024-04-02
  • 绑定域名的作用是什么
    域名是搜索引擎抓取的基本标志,而绑定域名是指将域名与主机或服务器的空间进行绑定,当网站空间与域名进行绑定并且解析后,用户才可以通过域名访问到网站,从而给网站带来流量;网站绑定域名后可以被搜索引擎收录,用户可以通过百度或者其他搜索引擎访问到网...
    99+
    2024-04-02
  • Vue快速理解事件绑定是什么
    目录一、监听事件二、事件修饰符1、stop修饰符阻止事件冒泡2、capture修饰符3、self修饰符4、prevent修饰符5、键盘事件修饰符6、鼠标事件修饰符一、监听事件 监听事...
    99+
    2024-04-02
  • jquery中如何对事件进行绑定和解绑
    小编给大家分享一下jquery中如何对事件进行绑定和解绑,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!jQuery事件绑定和解绑...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作