我們知道通過瀏覽器內建的innerHTML 屬性能夠擷取節點的所包含的字串的值,比如有如下節點:
複製代碼 代碼如下:
<div id="test"><strong>i'm strong</strong></div>
通過
複製代碼 代碼如下:
var obj=document.getElementById("test");alert(obj.innerHTML);//返回的值是<strong>i'm strong</strong>
如果我想得到節點的文本值,也就不包括標籤以為的字串,怎麼辦呢。這裡的文本值是:i'm strong
//非Mozilla瀏覽器:obj.innerText;//其他的瀏覽器obj.firstChild.nodeValue;
先提供一個通用的方法來解決相容問題:
完整代碼如下:
代碼
<html> <head> <title>title</title> </head> <body> <div id="test"><strong>i'm strong</strong></div> <script type="text/javascript"> var obj=document.getElementById("test"); //相容瀏覽器擷取節點文本的方法 function text(e){ var t=""; //如果傳入的是元素,則繼續遍曆其子項目 //否則假定它是一個數組 e=e.childNodes||e; //遍曆所有子節點 for(var j=0;j<e.length;j++){ //如果不是元素,追加其文本值 //否則,遞迴遍曆所有元素的子節點 t+=e[j].nodeType!=1?e[j].nodeValue:text(e[j].childNodes); } //返回區配的文本 return t; } alert(text(obj)) </script> </body> </html>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
讓FireFox支援innerText的實現代碼
轉載請註明來自:http://www.cnblogs.com/wbkt2t/