2025-05-17

一直以來對於通過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軟件聯盟 

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *