Heim  >  Artikel  >  Web-Frontend  >  关于Mozilla浏览器不支持innerText的解决办法_javascript技巧

关于Mozilla浏览器不支持innerText的解决办法_javascript技巧

WBOY
WBOYOriginal
2016-05-16 18:12:29897Durchsuche

比如:

Hello , world!


我们使用代码:alert((document.getElementById("test")).innerText)

在IE、Chrome中,均能获取到“Hello , world!”,但是在Firefox中,却得到了"undefined"。其原为是firefox中并不支持元素的innerText这个属性。当然,在网络上已经有很多好的方法来解决这个问题了,比如给HTMLElement原型添加一个属性(读取器)。

然而,所有文本节点都具有nodeValue属性,而且所有浏览器都是支持的。我们可以尝试用这种方法去读取一个HTML元素内的文本。
下面的原码,正好解决了这个问题:
复制代码 代码如下:

function getText(e) {
//若浏览器支持元素的innerText属性,则直接返回该属性
if(e.innerText) { return e.innerText; }
//不支持innerText属性时,用以下方法处理
var t = "";

//如果传入的是一个元素对象,则继续访问其子元素
e = e.childNodes || e ;

//遍历子元素的所有子元素
for(var i=0; i//若为文本元素,则累加到字符串t中。
if(e[i].nodeType == 3) { t += e[i].nodeValue; }

//否则递归遍历元素的所有子节点
else { t += getText(e[i].childNodes); }
}

return t;
}

有了这个函数,我们再来看看如下DOM结构:

Hello , world!


然后,我们用:
alert(getText(document.getElementById("test"));
在IE、Chrome、Firefox中均能获取到 "Hello, world!"
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn