首頁 >web前端 >js教程 >javascript中$(function() {});寫與不寫有哪些差別

javascript中$(function() {});寫與不寫有哪些差別

高洛峰
高洛峰原創
2017-01-04 16:10:491326瀏覽

javascript中$(function() {....}) 是jQuery 中的經典用法,等同於 $(document).ready(function() {....}),即在頁面載入完成後才執行某個函數,如果函數中要操作DOM,在頁面載入完成後再執行會比較安全,所以在使用jQuery 時這樣的寫法很常見。

$(document).ready() 裡的程式碼是在頁面內容都載入完才執行的,如果把程式碼直接寫到script標籤裡,當頁面載入完這個script標籤就會執行裡邊的程式碼了,此時如果你標籤裡執行的程式碼呼叫了目前還沒載入過來的程式碼或dom,那麼就會報錯,當然如果你把script標籤放到頁面最後面那麼就沒問題了,此時和ready效果一樣。

$(document).ready(function(){})可以簡寫成$(function(){});

點選段落後,此段落隱藏:

<html>
<head>
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function(){
 $("p").click(function(){
 $(this).hide();
 });
});
</script>
</head>
<body>
 <p>If you click on me, I will disappear.</p>
</body>
</html>

如果把$(document).ready(function () {});去掉後,無法隱藏段落:

<html>
<head>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript">
 $("p").click(function(){
 $(this).hide();
 });
</script>
</head>
<body>
 <p>If you click on me, I will disappear.</p>
</body>
</html>

但是把script放到頁面最後的話,就可恢復隱藏效果:

<html>
<head>
</head>
<body>
 <p>If you click on me, I will disappear.</p>
</body>
<script type="text/javascript" src="jquery-1.7.2.min.js"></script>
<script type="text/javascript">
 $("p").click(function(){
  $(this).hide();
 });
</script>
</html>

javascript 中(function(){})()的作用和用法有哪些

和對象啥的沒關係
(function(){})() 代表立即執行一個匿名的方法
一般用來與外界隔絕  製造一個似閉包的環境創建一個作用域鏈避免變量衝突

(function(){
 var a;
..........
})()

這篇文章主要介紹了javascript中$(function() {});寫與不寫有哪些差別,希望對大家有幫助。

更多javascript中$(function() {});寫與不寫有哪些區別相關文章請關注PHP中文網!


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