位置: 编程技术 - 正文

jQuery绑定事件的四种方式介绍(jq 绑定事件)

编辑:rootadmin

推荐整理分享jQuery绑定事件的四种方式介绍(jq 绑定事件),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery绑定函数,jquery绑定mouseover事件,jquery常用的事件绑定函数有哪些,jquery的绑定事件有几种方式,jquery绑定onchange事件的方法,jquery的绑定事件有几种方式,jquery绑定onchange事件的方法,jquery的绑定事件有几种方式,内容如对您有帮助,希望把文章链接给更多的朋友!

jQuery提供了多种绑定事件的方式,每种方式各有其特点,明白了它们之间的异同点,有助于我们在写代码的时候进行正确的选择,从而写出优雅而容易维护的代码。下面我们来看下jQuery中绑定事件的方式都有哪些。

jQuery中提供了四种事件监听方式,分别是bind、live、delegate、on,对应的解除监听的函数分别是unbind、die、undelegate、off。在开始看他们之前

一:bind(type,[data],function(eventObject))

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

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

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

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

bind的源码:

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

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

二:live(type, [data], fn)

jQuery绑定事件的四种方式介绍(jq 绑定事件)

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

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

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

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

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

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

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

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

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

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

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

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

以上所述是小编给大家介绍的jQuery绑定事件的四种方式介绍,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!

使用 jQuery.ajax 上传带文件的表单遇到的问题 今天帮人看代码的时候,遇到一点小问题。使用jQuery上传带文件的表单时,会有些问题。首先,因为使用的是FormData,所以必须在传入$.ajax的参数中配置

jQuery双向列表选择器DIV模拟版 前段时间项目需要用到双向列表选择,想直接用select,结果发现某些样式不支持,只好用div模拟了以下,功能基本实现能用了,需要其他功能自己加上

jQuery双向列表选择器select版 在上篇文章给大家介绍了div模拟版链接:

标签: jq 绑定事件

本文链接地址:https://www.jiuchutong.com/biancheng/379383.html 转载请保留说明!

上一篇:jQuery grep()方法详解及实例代码(jquery get(0))

下一篇:使用 jQuery.ajax 上传带文件的表单遇到的问题

  • 小规模纳税人每季度超过30万交税
  • 所得税预缴申报表资产总额怎么填
  • 股权转让所得如何申报个税
  • 外购货物用于什么不得抵扣进项
  • 小规模税控设备维护费怎么填申报表格
  • 一般纳税人变成小规模 在电子税务局哪里可以找到
  • 足球俱乐部买卖球员的程序
  • 离境退税政策文件
  • 资产负债表预收预付账款怎么填
  • 商业房产出租和租赁区别
  • 公司一直没有做内账违法吗
  • 公司注销清算时房租到期怎么办
  • 印花税 企业
  • 水利申报怎么申报
  • 2018年终奖个人所得税计算器公式
  • 规范合同签订的重要性
  • 备用金 退款
  • 所得税季报填写说明
  • 海关新增成交方式exw条款,如何退税?
  • 资产损失税前扣除备查资料
  • 辞退员工会计分录
  • 印花税计税金额是含税还是不含税
  • 评估的房产如何入账
  • 劳务公司费用成本怎么算
  • 非金融企业之间的借款合同要交印花税吗
  • 残保金零申报但是逾期未报
  • 计提待摊费用怎么记账
  • 管理费用如何分摊到产品成本
  • 苹果mac系统怎么截屏快捷键
  • 财政补助收入核算内容
  • 子公司取得投资收益
  • 新车事故报废后保险公司赔多少
  • 将城镇生活垃圾直接用作肥料
  • php删除指定字符串
  • 寓意幸福和团圆的网名
  • php读取php文件内容
  • win11显卡驱动不兼容
  • 计提支付公积金
  • 税控盘抵扣怎么做账
  • 广告费成本包括哪些内容
  • 应交税费中应交企业所得税为负数怎么调报表
  • 研发费用范围归集不正确
  • 投资收益收到的现金增加的原因
  • 金蝶固定资产累计折旧凭证生成
  • 预收账款期末余额在借方还是贷方
  • 个体工商户要做账报税吗
  • 税务处理决定书和处罚决定书
  • 实收资本冲减了工商年检怎么办呢
  • 什么叫金税四期呢?
  • 公司没有车油费可以报销吗
  • 税务局多扣的税可以退吗
  • 本月无进项发票需要去增值税发票认证平台吗
  • 公司里的废品的处理一般是谁负责
  • 员工体检的发票在哪里开
  • 其他业务收入冲减应付账款
  • 公司入账是什么意思
  • 银行承兑汇票怎么看
  • 加工企业三种商业模式
  • sqlserver 储存过程
  • 数据库中的内容怎么换行
  • winxp电脑显示器亮度怎么调
  • win10周年更新版是什么意思
  • freebsd ip配置
  • xp系统如何禁止各种窗口弹出
  • win7升级win10黑屏
  • linux压缩.z
  • process32first 进程信息为空
  • win7怎么隐藏软件
  • win10麦克风无法说话
  • linux系统ll
  • 微信小程序获取手机号失败
  • python的pip安装命令
  • npm安装淘宝镜像操作方式
  • shell操作
  • Python字符串大写
  • python如何编写
  • python搭建网站并在服务器上部署
  • 互城通怎么用微信充值
  • 广东省税务局登录
  • 个体工商户银行卡是对公还是对私
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设