位置: 编程技术 - 正文

jQuery的Read()方法代替原生JS详解(jquery onready)

编辑:rootadmin

推荐整理分享jQuery的Read()方法代替原生JS详解(jquery onready),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery的ready方法,jquery的ready方法,jquery(document).ready,jquery中的ready函数,jquery onready,jquery中的ready函数,jquery中的ready函数,jquery的ready方法,内容如对您有帮助,希望把文章链接给更多的朋友!

在jQuery 3.0的版本前, ready经典用法是用一个匿名函数,像这样:

jQuery 3.0 ready() 变化

在jQuery 3.0发布之前,有以下几种方法称之为ready方法:

在document元素上操作: $(document).ready(handler);

在空元素上操作: $().ready(handler);

或者直接(即不在一个具体的元素上)操作: $(handler);

上述所有命名的变种在功能上是等价的。无论是哪个元素,在DOM加载完毕之后其指定的处理程序都将会被调用。换句话说,这里的DOM加载完毕并不表示在文档中的某个具体的元素,比如img元素,加载完毕。相反,这里表示的是整个DOM树加载完毕。

在jQuery 3.0中,除了$(handler) 其他的ready方法都被弃用。

官方声明为此:

这是因为选择器并没有和ready()建立联系,不仅低效而且会导致浏览器引擎对该方法的行为进行不正确的假设。

ready 事件和 load 事件的区别

当DOM加载完毕且元素能够被安全访问时就会触发ready事件。另一方面,load事件却在DOM和所有资源加载后触发。

jQuery的Read()方法代替原生JS详解(jquery onready)

可以像下面这样使用load事件:

这样的话,不仅仅要等到DOM结构能完全访问,而且还需要等到所有的图片资源完全加载完毕(加载时间取决于图片文件大小)才能执行函数。

正常的DOM操作你可能不需要load事件,但是如果你想要在所有的资源被加载完毕之前展示一个旋转的加载器样式,比如,又或者你想要用JS计算一下图片的大小,这可能是一个好的选择。

你可能不需要jQuery.ready()

ready 方法可以确保代码只在所有DOM元素能被安全操纵时才执行。 但这意味着什么呢?这意味着当你要执行的js代码嵌在HTML中某个片段中时,浏览器也要加载完以下元素才能执行。

就像下面这个例子一样:

如果你要执行的javascript代码放在body末尾,你就可能不需要使用ready()方法,因为浏览器解析到javascript时你可能试图操纵和访问的DOM元素已经被加载完了:

原生JavaScript ready()替代

对于现代浏览器以及IE9+,你可以通过监听 DOMContentLoaded 事件实现ready()相同的功能:

但是,请注意,如果事件已经发射,回调将不会被执行。为了确保回调总是运行,jQuery检查文档reference)的“readyState”属性,如果属性值变为 complete,则立即执行回调函数:

包括domReady库,已经实现了这个解决方案。

老版本的IE浏览器

对于IE8及以下的浏览器,你能使用onreadystatechange 事件去监听文档的readyState 属性:

或者你可以使用Load事件,如jQuery,这样可以在任何浏览器上运行。这也会导致一个时间延迟,因为它会等待所有的资产被加载。

注意,在这个解决方案中你也要检查readyState,如上文所述,这样能确保回调总是能够被执行。

总结

标签: jquery onready

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

上一篇:Jquery通过ajax请求NodeJS返回json数据实例

下一篇:jQuery自定义组件(导入组件)(jquery自定义表单)

  • 办公费税前扣除标准2023
  • 可供出售金融资产包括哪些内容
  • 公司收到分红怎么交税
  • 已经作废的发票还需要申报吗
  • 残疾人保障金零申报怎么填写
  • 会计核算过程中的计量尺度通常有
  • 应收账款换入固定资产双方账务处理
  • 汽车行业保险丝
  • 新建厂房房产证办理流程
  • 车间报废产品改善方式
  • 一般纳税人购入货物相关的增值税可以抵扣
  • 合同额在3000以下的是否缴纳印花税?
  • 贸易利益怎么计算
  • 企业去年
  • 企业年薪扣税政策
  • 公司变更监事需要换营业执照吗?
  • 支付法院执行款的账务处理
  • 超市预付卡过了还能退吗
  • 利润为负数怎么调
  • 无线路由器指示灯怎么才是正常
  • 如何生成系统图
  • PHP:mb_encode_numericentity()的用法_mbstring函数
  • 生产企业结账流程
  • w10怎么找蓝牙
  • Windows11预览体验计划空白
  • 赔偿材料做什么分录
  • 所有者权益的确认主要依赖于什么
  • 高新企业政府补贴政策
  • php image
  • 公司修好厂房老板怎么说
  • 总公司给分公司调货
  • 大雾山国家公园总部加特林堡
  • php用img显示图片
  • 圆顶山遗址
  • 任意公积金可以不提取吗
  • 债务重组收益会计处理
  • 季度缴纳企业所得税计算方法
  • 债务重组收入要交税吗
  • php使用while循环计算1到100的和
  • pytorch torch
  • 已入账的发票跨年退回税务
  • verilog hdl中任务可以调用
  • python中如何获取列表中的元素
  • 公司股东和自然人的关系
  • 企业应付账款科目的借方余额反映的是
  • 更正申报会扣分吗
  • 扣缴义务人如何登录电子税务局
  • mysql的主从
  • 报销招待费的会计科目
  • 加计抵减不符合怎么办
  • 劳动保护费是否可以抵扣
  • 刷单成本计入什么费用?
  • 账户外币转人民币
  • 折旧计入主营业务成本的情况
  • 研发费用和研发支出的会计处理
  • 货款已付,货未收到分录
  • mysql zip archive 版本(5.7.19)安装教程详细介绍
  • 连接mysql数据的四要素
  • navicate创建存储过程
  • 微软数据收集
  • win7系统对拷的方法
  • mm pp dpps进程
  • win8系统运行在哪里
  • windows无法更改设置
  • centos如何删除bond
  • 苹果怎样快速移动应用到其他桌面
  • win7系统鼠标指针异常
  • win8.1黑屏
  • cocos2dx怎么用啊
  • 使用css实现全兼容的方法
  • 骨骼动画原理
  • 深入浅出javascript
  • JavaScript中的复杂数据类型又称为
  • unity人物面板
  • jQuery ajax MD5实现用户注册即时验证功能
  • JavaScript中关于模板字符串
  • js鼠标滚动控制图片缩放
  • javascript操作网页
  • 类库怎么用
  • 预征率是2%怎么计算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设