以前一直覺得script在html的任何位置都可以,今天做一個需求的時候才更正了自己的錯誤思想啊--script的位置也不是隨便放的。 首先是想實作一個select標籤,有是和無兩個option,但是在初始化的時候要求select標籤預設選擇空值,所以我在點擊的時候加了一個方法讓他把空值刪除: $('#checkcash').click(function () { if ($('#checkcash').val() == '0') { $("#checkcash option[value='0']").remove(); } }); $("#alert").click(function(){ alert("1123"); }) 是否已提现 是 否 登入後複製但是這樣並不能達到想要的效果,起初以為是jquery語法錯誤還一直在網上查,改,但是都不管用,後來突然想到是不是我應該把script放到後面,試了一下,結果果真ok了,這才恍然大悟,原來不是這樣的。 後來查了一下原因是因為,html檔案是自上而下的執行方式,但引入的css和javascript的順序有所不同,css引入執行載入時,程式仍然往下執行,而執行到腳本是則中斷線程,待該script腳本執行結束之後程式才繼續往下執行。所以,一般將script放在body之後是因為避免長時間執行script腳本而延遲阻塞。而有一些頁面的效果的實現,是需要預先動態的載入一些js腳本,所以這些腳本應該放在<body>之前。 <span style="color: #ff0000;">其次,不能將需要存取dom元素的js放在body之前,因為此時還沒有開始產生dom,所以在body之前的存取dom元素的js會出錯,或無效。 <span style="color: #000000;">就是因為這個,在dom沒生成好時我就給它添加了方法,才導致這樣。 </span></span></p> <p><span style="color: #ff0000;"><span style="color: #000000;">真的應該多學習很多地方以為所以然了,卻沒深究。以後還要加油! </span></span></p> <p> ps:其實還有另一個方法,就是用jquery的初始化頁面方法,把上面給標籤添加的點擊<a href="http://www.php.cn/js/js-jspopular-guide-event.html" target="_blank">事件</a>加入到$(function (){})中也是可以的,原理和上面是一樣的,這個方法是等頁面加載好了才執行,所以不管放在哪裡都可以了! </p>