位置: 编程技术 - 正文

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自定义表单)

  • 收客户刷卡手续费时客户不愿意缴费,如何处理
  • 个税手续费返还比例
  • 外贸企业指的是什么
  • 材料出入库制度
  • 暂估成本会计处理
  • 制造费用计入营业成本吗
  • 法院拍卖房法院有什么义务和责任
  • 利润表的企业所得税怎么查询
  • 全资子公司需要设立股东会吗
  • 税务的电子钥匙是干嘛的
  • 南方建筑主编
  • 托儿所幼儿园卫生保健工作规范2022
  • 国有划拨地是否能转让土地
  • 节日现金福利征收个人所得税吗
  • 总公司签合同发票可以给子公司吗
  • 公司开业期间的费用入管理费用其他行吗
  • 怎么辨别是非
  • 财政票据税务局能查到吗
  • 苹果手机m开头的序列号代表什么
  • windows10如何关闭病毒和威胁防护设置
  • 公司章程认缴时效是多久
  • 冲减多计提的工会经费调账说明
  • 长期股权投资权益法四个明细科目
  • 物业公司营业成本包括哪些
  • php怎么添加样式
  • php 7z
  • 月末结转未分配利润吗
  • wordpress怎么上传网站
  • 合同违约金可以全额扣除吗
  • 莱姆 惨败
  • pytorch说明文档
  • 毛地黄长什么样
  • vue环境搭建及配置简书
  • framework core
  • php自带的加密解密函数
  • 大语言模型集成工具
  • 使用vue要安装什么软件
  • 设备租赁经营部经营范围
  • 史上伟大电影
  • 利息收入怎么做账务处理
  • 对企业采取以旧换新方式销售的应税产品
  • 应收账款资产负债表负数
  • 什么是稳岗补贴是给企业发放吗
  • 简易征收的进项税怎么处理
  • 2022年我们国家将举行什么样的盛会
  • 存货跌价准备转回的条件有哪些
  • 出口免抵增值税税率
  • 企业的预付账款属于金融资产吗
  • 固定资产一次性计入费用的账务处理
  • 职工薪酬都包括什么
  • 个人独资企业法人可以发工资吗
  • 房地产企业何时确认收入结转成本
  • 成本利润率多少是正常的
  • 企业注销递延所得税资产怎么处理
  • 需要计提坏账准备吗
  • 营业外收入是否影响营业利润
  • 会计报表的主要构成内容
  • mysql主从复制原理详解
  • win7经典版怎么换回win10
  • ssh连接虚拟机centos
  • macbookpro怎么提升性能
  • linux系统的介绍
  • linux批量操作
  • win7系统锁屏密码
  • hyper-v以后安装操作系统
  • 苹果电脑装win7键盘无法使用
  • win7开机提示音在哪里关闭
  • win7 u盘不显示
  • node.js 流
  • python颜色表
  • shell的使用
  • js设置图片大小
  • python中pyinstaller
  • flask框架代码
  • python中如何抛出异常
  • 财务跨期报销问题
  • 消费税申报流程图
  • 生产变压器有什么危害
  • 什么是契税发票?
  • 创新税务稽查方案
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设