位置: 编程技术 - 正文

使用jQuery监听DOM元素大小变化(jquery监听span内容的变化)

编辑:rootadmin

推荐整理分享使用jQuery监听DOM元素大小变化(jquery监听span内容的变化),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery监听span内容的变化,jquery监听窗口大小,jquery监听div属性变化,jquery监听数据变化,jquery监听数据变化,jquery监听div属性变化,jquery 监听,jquery监听div属性变化,内容如对您有帮助,希望把文章链接给更多的朋友!

起因

今天写页面的时候突然有这么个需求,由于父元素(一个DIV)的height是由javascript计算出来的固定的值,而在其中增加了一个多说插件,在用户评论后,子元素(DIV)的height属性增加,导致子元素溢出。但是又不知道如何为多说的评论按钮增加回调函数,于是乎就想到了根据子元素的大小变化来重新计算父元素的height。

onresize&#;

平常,都是在整个浏览器窗口变化时触发一个修改布局的回调函数。使用的是window对象的resize事件,利用:

来绑定。但根据resize事件的target是defaultView (window),这里详见MDN的resize文档,也就是说只有window对象有resize事件,于是乎就想到使用jQuery自己的事件机制来模拟一个普通元素上的resize事件

使用JQUERY事件的实现思路

可以想到一种比较简单的方式:

1. 在元素绑定resize对象时,记录元素的width和height2. 使用requestAnimationFrame、setTimeout、setInterval,每隔一段时间查询其width和height,如果和记录的width和height不一样,运行回调函数并更新记录中的width为height

使用jQuery监听DOM元素大小变化(jquery监听span内容的变化)

JQUERY插件

这个功能Ben Alman编写了一个jQuery插件,传送门该插件的代码(核心部分),详细代码请查看Ben Alman博客的内容:

jQuery为jQuery插件的开发者提供了添加自定义事件的接口,详细可以参考jQuery官方文档,这里就是典型的jQuery自定义事件添加方式,其中有三个钩子:

1. setup:The setup hook is called the first time an event of a particular type is attached to an element.首次绑定时执行,如果返回 false,使用默认方式绑定事件2. teardown:The teardown hook is called when the final event of a particular type is removed from an element.若指定该方法,其在移除事件处理程序(removeEventListener)前执行,如果返回 false,移除默认绑定事件3. add:Each time an event handler is added to an element through an API such as .on(), jQuery calls this hook.每一次给元素绑定事件,都会执行这个方法

setup、teardown和add三个钩子,每个钩子最先做的事都是检测是否该对象为window对象,然后根据window对象特殊处理,因为window对象本身有resize事件

从setup钩子可以看到,在初始化整个事件处理时,创建一个元素队列,队列中的每隔元素都把width和height放在data中,然后每隔ms启动loopy函数,在loopy函数中判断是否变化,如果有变,触发回调函数并更新data中的width和height

从teardown钩子可以看到,在元素移除事件时,只需要将元素从元素队列移除,并清除元素中的data数据。如果是元素队列中的最后一个元素,则不再继续执行loopy

add钩子中,对回调函数进行了包装

由此可以看到一个简单的jQuery自定义函数的实现机制

JQuery EasyUI的使用 jQueryEasyUI是一个基于jQuery的框架,集成了各种用户界面插件。EasyUI简介easyui是一种基于jQuery的用户界面插件集合。easyui为创建现代化,互动,JavaScript应

jQuery+formdata实现上传进度特效遇到的问题 总结我做HTML5文件上传插件遇到的技术问题先贴上源码:fileupload-html5.js(PS:公司使用seajs框架)问题列表1.JQUERY.AJAX没有监听上传进度的ONPROGRESS事件。2.XM

浅析jQuery Ajax请求参数和返回数据的处理 刚接触学会用jQueryajax的时候,觉得真东西好神奇,这样就可以把数据取回来了啊。然后我可以把取回来的数据渲染到页面上,一颗赛艇。之前很早接触

标签: jquery监听span内容的变化

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

上一篇:jQuery中判断对象是否存在的方法汇总(jquery判断对象是否存在)

下一篇:JQuery EasyUI的使用(jquery easy ui)

  • 房产税出现往期数据怎么办
  • 年初存货跌价准备余额是上年末结转的吗
  • 盈利能力也可以反映短期偿债能力
  • 手撕票几个点
  • 建筑企业劳务工资必须要开劳务发票吗?
  • 材料实际成本包括哪些内容
  • 政府会计制度中累计盈余怎么计算
  • 融资租赁咨询服务合同需要交印花税吗
  • 公司补贴怎样做分录?
  • 企业成立股东没有实际出资分录怎么写?
  • 企业更名后账务如何处理
  • 建筑公司挂靠项目账务怎么做?
  • 捐赠个人支出需要交纳个税吗?
  • 未报税会怎么样
  • 企业发放工资时,可能涉及的会计科目有
  • 电子发票开给个人怎么处理?
  • 个税如何绑定新公司
  • 其他应付款借贷方分别表示什么
  • win11正式版好用吗
  • win11怎么取消登录pin密码
  • 收到的增值税专用发票如何认证
  • 欠税不交的后果 个人
  • php中如何使用session
  • win11系统怎么删除账户
  • 刚收到的假发怎么处理
  • vue程序运行过程
  • echarts饼图标题
  • 安装了sklearn调用却找不到
  • 企业怎么知道增值税的核定方法
  • 发票抵扣联能报销吗
  • 单位车辆车船使用税滞纳金如何交
  • 住宿费电子发票没有章
  • 给工程项目买保险合法吗
  • 新注册的小公司要登记社保吗
  • 一般纳税人购进免税农产品如何抵扣进项税额
  • 研发费用资本化计入什么科目
  • 公司食堂的费用分录
  • 机关单位差旅费
  • php屏蔽ip
  • 已认证发票对方作废后不重开怎么办
  • 收到的存款利息
  • 关联企业债资比怎么计算
  • 购进货物用于建筑安装
  • 农产品进项税额抵扣范围
  • 付款方押金无法退还
  • 个人独资企业一般纳税人享受六税两费
  • 什么叫印花税税率
  • 如何把有余额的账单删除
  • 发票税额不全能抵扣吗
  • 投资性房地产的定义
  • 公司买灭草剂怎么入账
  • 考核员工的罚款计入什么
  • 社保费申报是当月的
  • 销售收入指开票金额吗
  • 残保减免金政策
  • 进项税额转出科目编码
  • 员工在外餐费怎么做账
  • mysql通过find_in_set()函数实现where in()顺序排序
  • win8怎么查看系统版本
  • 如何解决windows10数据放到国外进行处理
  • won10安装
  • win8双桌面
  • ibm文件是什么意思
  • fsm32.exe是什么进程 有什么作用 fsm32进程查询
  • onionwormimmune.exe是什么
  • win7系统无法更改账户名称
  • 基于核心素养下的大单元教学设计
  • unity怎么用
  • js获取tbody
  • Linux CentOS系统下安装node.js与express的方法
  • python ip地址转换
  • js复制字符串的方法
  • Javascript字符串对象函数
  • jquery更换图片
  • 房产税的计税依据与税率分别是什么
  • 如何加强木材加工质量
  • 国家税务局查询发票
  • 通用机打发票明细怎么导出电子版
  • 扶贫绩效目标申请怎么写
  • 怎么查询车船税缴费记录
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设