JS ready和onload事件 比較分析
阿新 • • 發佈:2019-02-14
3.執行先後順序不同
對於Body.Onload事件,是在載入完所有頁面內容才會觸發,我的意思是所有內容,包括圖片,flash等.如果頁面的這些內容很多會讓使用者等待很 長時間.
而對於$(document).ready()方法,這個方法只是在頁面所有的DOM載入完畢後就會觸發,無疑很大的加快了網頁的速度.
但是對於一些特殊應用,比如圖片的放大縮小,圖片的剪裁。需要網頁所有的內容載入完畢後才執行的呢?我推薦使用$(window).load()方法,這 個方法會等到頁面所有內容載入完畢後才會觸發,並且同時又沒有OnLoad事件的弊端.
<script type="text/javascript">
$(window).load(function() {
alert("hello");
});
$(window).load(function() {
alert("hello again");
});
</script>
上面的程式碼會在頁面所有內容載入完成後按先後順序依次執行.
當然不要忘了與之對應的Unload方法
$(window).unload(function() {
alert("good bye");
});
上面程式碼會在頁面關閉時引發.
在 所有DOM載入之前引發JS程式碼
這個方法是我在除錯的時候最喜歡的,有時候開發的時候也用這種方法
<body>
<script type="text/javascript">
(function() {
alert("hi");
})(jQuery)
</script>
</body>
對, 就是利用js閉包的形式將js程式碼嵌入body,這段程式碼會自動執行,當然也可以直接嵌入js程式碼,這種方式要注意順序問題,如下:
<body>
<div id="test">this is the content</div>
<script type="text/javascript">
對於Body.Onload事件,是在載入完所有頁面內容才會觸發,我的意思是所有內容,包括圖片,flash等.如果頁面的這些內容很多會讓使用者等待很 長時間.
而對於$(document).ready()方法,這個方法只是在頁面所有的DOM載入完畢後就會觸發,無疑很大的加快了網頁的速度.
但是對於一些特殊應用,比如圖片的放大縮小,圖片的剪裁。需要網頁所有的內容載入完畢後才執行的呢?我推薦使用$(window).load()方法,這 個方法會等到頁面所有內容載入完畢後才會觸發,並且同時又沒有OnLoad事件的弊端.
<script type="text/javascript">
$(window).load(function() {
alert("hello");
});
$(window).load(function() {
alert("hello again");
});
</script>
上面的程式碼會在頁面所有內容載入完成後按先後順序依次執行.
當然不要忘了與之對應的Unload方法
$(window).unload(function() {
alert("good bye");
});
上面程式碼會在頁面關閉時引發.
在 所有DOM載入之前引發JS程式碼
這個方法是我在除錯的時候最喜歡的,有時候開發的時候也用這種方法
<body>
<script type="text/javascript">
(function() {
alert("hi");
})(jQuery)
</script>
</body>
對, 就是利用js閉包的形式將js程式碼嵌入body,這段程式碼會自動執行,當然也可以直接嵌入js程式碼,這種方式要注意順序問題,如下:
<body>
<div id="test">this is the content</div>
<script type="text/javascript">