亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

js onreadystatechange 和 onload區別

js onreadystatechange 和 onload區別

素胚勾勒不出你 2019-05-16 10:10:23
js onreadystatechange 和 onload區別
查看完整描述

2 回答

?
炎炎設計

TA貢獻1808條經驗 獲得超4個贊

在Jquery里面,我們可以看到兩種寫法:$(function(){}) 和$(document).ready(function(){})
這兩個方法的效果都是一樣的,都是在dom文檔樹加載完之后執行一個函數(注意,這里面的文檔樹加載完不代表全部文件加載完)。
而window.onload是在dom文檔樹加載完和所有文件加載完之后執行一個函數。也就是說$(document).ready要比window.onload先執行。
那么Jquery里面$(document).ready函數的內部是怎么實現的呢?下面我們就來看看:
我們來為document添加一個ready函數:

document.ready = function (callback) {
///兼容FF,Google
if (document.addEventListener) {
document.addEventListener('DOMContentLoaded', function () {
document.removeEventListener('DOMContentLoaded', arguments.callee, false);
callback();
}, false)
}
//兼容IE
else if (document.attachEvent) {
document.attachEvent('onreadytstatechange', function () {
if (document.readyState == "complete") {
document.detachEvent("onreadystatechange", arguments.callee);
callback();
}
})
}
else if (document.lastChild == document.body) {
callback();
}
}

document.ready這個函數是實現了。我們再來驗證一下最上面所說的“ready要比onload先執行”:

window.onload = function () {
alert('onload');

};

document.ready(function () {
alert('ready');

});

執行這段代碼之后,你會看到瀏覽器里面會先彈出“ready”,在彈出onload。




查看完整回答
反對 回復 2019-05-17
  • 2 回答
  • 0 關注
  • 361 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號