jQuery是如何判断HTML页面加载完毕的?它的原理是什么?
jQuery判断HTML页面加载完毕用的不是
window.onload
。$(document).ready是在页面加载完毕时执行回调而window.onload是在页面全部加载完成时,包括一些资源比如图片。
所以window.onload比$(document).ready更延后一些。
window.onload自然不必说,是浏览器自身支持的。
但是$(document)
.ready
根据的是document.documentElement
对象去判断的。每次调用document.documentElement.scrollLeft方法如果此方法产生了异常,就说明scrollLeft无法执行,此时页面还未加载完成,所以就用try块包含这条语句,然后catch住,用setTimeout方法,重新执行一遍。直到scrollLeft可以执行时,就说明页面加载完成了,此时再去回调。
如何解决用js判断页面是否加载完成代码实例:示例如下,将下面信息复制保存成.html文件即可浏览到效果...
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>解决js判断页面是否加载完成代码实例</title>
<script type="text/javascript">
var ttd = null;
document.onreadystatechange = subSomething;//当页面加载状态改变的时候执行这个方法.
function subSomething() {
//if(document.readyState == "complete"&&window.parent.frames["框架名"].document.readyState == "complete") //当页面加载状态为完全结束时进入
(); //这是你的操作
if(document.readyState=="complete"){
//alert("当前页面已加载完成!");
box = document.getElementById("box"); //当页面加载完成后获得该元素对象
alert(box.value);
}
}
</script>
</head>
<body>
<div><input type="text" value="加载完成读取该元素值" id="box"/></div>
</body>
</html>
JS页面加载触发事件document.ready和onload的区别?
1.document.ready是jquery提供的,正确的写法如下:$(document).ready(function(){ // ......});因为这么些比较麻烦,所以一般使用简写的方式,如下:$(function(){ // ....})
;2.关于document.ready与onload的相同点:都是在页面加载完成后执行方法体中的代码;
不同点:document.ready可以绑定多个函数,js根据定义的顺序,依次执行各个方法体,onload不能定义多个,后面定义的会覆盖前面定义的,所以只会执行最后定义的方法。$(function(){ // 方法体1,页面加在后执行})
;$(function(){ // 方法体2,方法体1执行后执行})
;window.onload = function(){ // onload方法1}
;window.onload = function(){ // onload方法2,页面加载完成后执行,不会执行onload方法1 }