JavaScript獲取onclick、onchange等事件的值


         今天小菜處理下拉菜單級聯問題時,想獲取HTML標簽中某個事件的內容,也就是值,比如從<select id="city" onchange="javascript:test();"></select>中獲取javascript:test();。

小菜想通過事件中的信息,確定下一級的菜單,但是這個貌似很簡單的問題,卻讓小菜糾結了一番。

         稍微懂點JQuery的童鞋,可能會嘗試這樣獲取:

1 $(document).ready(function(){
2     var onchangeValue = $("#city").attr("onchange");
3     alert(onchangeValue);
4 });

 

         一般情況下,這樣的確可以獲取到,因為JQuery萬能的attr方法,可以獲取標簽中任何的”屬性”,即使是一個事件,也可以直接獲取內容,這里onchange就是事件。

         但小菜在實際開發環境中,用這個方法怎么也獲取不到,得到的均是undefined。

         在糾結之際,發現了另外一種用純JavaScript實現獲取的方法。

         具體代碼如下:

1 $(document).ready(function(){
2     var onchangeValue = document.getElementById("city").getAttributeNode("onchange").nodeValue;
3     alert(onchangeValue);
4 });

 

         簡單說一下,這里主要是用到了getAttributeNode()這個方法,它獲取的是屬性節點,忽略屬性和事件的差別,類似於對XML的處理,然后再用nodeValue獲得屬性節點的節點值。

         如果使用getAttribute()方法,由於onchange是一個事件,因此獲取的是一個函數對象,無法當成字符串處理。

 

         希望這篇文章能夠幫助需要的童鞋。。。。。

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM