首頁 >web前端 >js教程 >JQuery Tips相關(1)----關於$.Ready()_jquery

JQuery Tips相關(1)----關於$.Ready()_jquery

WBOY
WBOY原創
2016-05-16 16:39:371619瀏覽

 最近一直在研究JQuery,這個東西還是很博大精深的.下面分享一下我的學習總結.

$(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數.所以第二段程式碼無法正確顯示.

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn