一直以來對於通過jQuery方式獲取的對象使不能直接使用JavaScript的一些方法的,開始的時候不理解,現在此案知道,原來jQuery獲得的對象並不和我們平時使用getElementById獲得的對象是一樣的對象。所以一些新手就很迷惑,為什麼${"#Element"}不能直接innerHTML,這就是原因所在,解決方式請看下文。
jQuery對象與dom對象的轉換
隻有jquery對象才能使用jquery定義的方法。註意dom對象和jquery對象是有區別的,調用方法時要註意操作的是dom對象還是jquery對象。
普通的dom對象一般可以通過$()轉換成jquery對象。
如:
$(document.getElementById("msg"))
則為jquery對象,可以使用jquery的方法。
由於jquery對象本身是一個集合。所以如果jquery對象要轉換為dom對象則必須取出其中的某一項,一般可通過索引取出。
如:
$("#msg")[0],$("p").eq(1)[0],$("p").get()[1],$("td")[5]
這些都是dom對象,可以使用dom中的方法,但不能再使用Jquery的方法。
以下幾種寫法都是正確的:
$("#msg").html();
$("#msg")[0].innerHTML;
$("#msg").eq(0)[0].innerHTML;
$("#msg").get(0).innerHTML;
摘自 張毅☆.Net★Java軟件聯盟