国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

JQuery下關于$.Ready()的分析

2024-05-06 14:12:21
字體:
來源:轉載
供稿:網友
$(document).Ready()方法 VS OnLoad事件 VS $(window).load()方法
接觸JQuery一般最先學到的是何時啟動事件。在曾經很長一段時間里,在頁面載入后引發的事件都被加載在”Body”的Onload事件里.

對于Body的Onload事件和JQuery的Ready方法相比,有很多弊端.比如:

1.加載多個函數的問題
<body onload="a();b();">
</body>

在Onload事件中只能這樣加載,很丑陋…而在JQuery中你可以利用多個JQuery.Ready()方法,它們會按次序依次執行

2.代碼和內容不分離
這個貌似不用說了,讓人深惡痛絕-.-!!

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">

alert($("#test").html());//I Can display the content

</script>
</body>
<body>

<script type="text/javascript">

alert($("#test").html());//I Can't display the content

</script>
<div id="test">this is the content</div>
</body>

上面兩段代碼,第二段代碼當中因為只能解釋到當前代碼之前的DOM,而test并不存在于已經解析的DOM數.所以第二段代碼無法正確顯示.
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 鹰潭市| 台安县| 黑龙江省| 德江县| 南汇区| 库尔勒市| 莎车县| 滦南县| 郎溪县| 莆田市| 西丰县| 吉林省| 靖边县| 金乡县| 甘孜| 汉川市| 襄汾县| 黔西县| 精河县| 大连市| 景洪市| 太仆寺旗| 合江县| 张掖市| 昔阳县| 宁化县| 林口县| 靖安县| 廉江市| 琼海市| 兴业县| 喜德县| 华蓥市| 达州市| 凤阳县| 抚宁县| 潜山县| 澄江县| 丰台区| 正阳县| 江孜县|