JQuery_$(document).ready() 与 $(window).load()方法比较

2024-05-03 07:32

本文主要是介绍JQuery_$(document).ready() 与 $(window).load()方法比较,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先介绍下HTML文档加载顺序:

①       解析HTML结构

②       加载外部脚本和样式表文件

③       解析并执行脚本代码

④       构造HTML DOM模型

⑤       加载图片等外部文件

⑥       页面加载完毕


Jquery页面加载中的几个主要函数

$(document).load();

当web页面以及其附带的资源文件,如CSS,Scripts,图片等,加载完毕后执行此方法。
常用于检测页面(及其附带资源)是否加载完毕。

$(document).ready();
当页面DOM对象加载完毕,web浏览器能够运行JS时,此方法即被触发。如果你想尽快执行JS,可以使用此方法。[在html的头部的script标签中的,不处于ready()中的JS代码将早于ready()执行]

$(document).unload();
此事件在停止浏览页面的时候触发,此操作可能存在于刷新操作/F5,单击上一页按钮,进入其他页面或关闭整个tab或窗口。

总而言之,他们的调用顺序是 ready() >> load() >> unload() 。



一 $(document).ready()

方法介绍:

JQuery的ready事件实际上是对IE的readystatechange事件和DOM的DOMContentLoaded事件进行封装,这两事件都是在DOM树结构下载并解析完毕后触发。

封装原形与分析:http://blog.csdn.net/lidiansheng/article/details/8008158

主要源码:  

 <script>var $ = ready = window.ready = function(fn){if(document.addEventListener){//兼容非IEdocument.addEventListener("DOMContentLoaded",function(){//注销事件,避免反复触发document.removeEventListener("DOMContentLoaded",arguments.callee,false);fn();//调用参数函数},false);}else if(document.attachEvent){//兼容IEdocument.attachEvent("onreadystatechange",function(){if(document.readyState==="complete"){document.detachEvent("onreadystatechange",arguments.callee);fn();}});}}$(function(){alert("ok1");});</script>

如果定义多个$().ready()函数则会按照顺序执行

如:

$(document).ready(function(){ 
alert(“Hello World”); 
}); 
$(document).ready(function(){ 
alert(“Hello again”); 
}); 

结果两次都输出 


执行时间:

$(document).ready()是DOM结构绘制完毕后就执行,不必等到加载完毕。 也就是不会等到图片,Flash全部加载完成后执行。


简写方法:

$(document).ready()过于冗长,有以下几种简写方法

复制代码代码如下:


$(function(){ 
// do something 
}); 


其实这个就是jq ready()的简写,它等价于: 

复制代码代码如下:


$(document).ready(function(){ 
//do something 
}) 


也等于下面这个方法,jQuer的默认参数是:“document”; 

复制代码代码如下:


$().ready(function(){ 
//do something 
}) 


  



二 $(window).load()

方法介绍:

$(window).load(function(){ }) 等同于 原生的 javascript 中 window.onload = function (){ }

但是也有一定的区别,

$(window).load 可以加载多个函数,如:

        $(window).load(function(){alert("加载中");});$(window).load(function(){console.log("打印4");});




window.onload 不能定义多个函数,若想执行多个函数,需要这样编写代码:

window.onload =function() { t();  b(); }  

这里有一篇博文介绍了如何让onload 执行多个event, http://www.cnblogs.com/jhxk/articles/1660528.html

ps:怕博文被删,自己先备份一篇吧


执行时间:

必须等待网页中所有的内容加载完毕后 ( 包括图片 ) .


简写方法:

一般写法

$(window).load(function (){ 
//do something
});


三 $(document).ready()与$(window).load()主要区别

由上面的栗子我们已经可以清楚的看到两个方法的主要区别在于:


$(window).load()必须等到页面内包括图片的所有元素加载完毕后才能执行。 

$(document).ready()是DOM结构绘制完毕后就执行,不必等到加载完毕。 


测试代码:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Onload和Ready的测试</title><script type="text/javascript" src="../js/jquery-1.9.1.min.js"></script><script>$(window).load(function(){alert("加载中");});$(window).load(function(){console.log("打印4");});$(window).load(function(){console.log("打印5");});$(function(){console.log("打印1");});$().ready(function(){console.log("打印2");});$(document).ready(function(){console.log("打印3");});</script>
</head>
<body><div style="height:200px; width:auto; background-repeat:no-repeat; background-image: url(../img/src1.jpg);"></div><img src="../img/src1.jpg"/>
</body>
</html>

测试结果;





这篇关于JQuery_$(document).ready() 与 $(window).load()方法比较的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/956165

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti