相容IE,firefox的擷取節點的文本值的javascript代碼_javascript技巧

來源:互聯網
上載者:User
我們知道通過瀏覽器內建的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/
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.