Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
140 views
in Technique[技术] by (71.8m points)

javascript - 'innerText'在IE中有效,但在Firefox中不可用('innerText' works in IE, but not in Firefox)

I have some JavaScript code that works in IE containing the following:

(我有一些可在IE中运行的JavaScript代码,其中包含以下内容:)

myElement.innerText = "foo";

However, it seems that the 'innerText' property does not work in Firefox.

(但是,似乎'innerText'属性在Firefox中不起作用。)

Is there some Firefox equivalent?

(是否有一些Firefox等效产品?)

Or is there a more generic, cross browser property that can be used?

(还是可以使用更通用的跨浏览器属性?)

  ask by Ray Vega translate from so

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

(Update)

: I wrote a blog post detailing all the differences much better.

((更新)

:我写了一篇博客文章,详细介绍了所有差异 。)

Firefox uses W3C standard Node::textContent , but its behavior differs "slightly" from that of MSHTML's proprietary innerText (copied by Opera as well, some time ago, among dozens of other MSHTML features).

(Firefox使用W3C标准的Node::textContent ,但是其行为与MSHTML的专有innerText (在一段时间之前由Opera复制,还有许多其他MSHTML功能)“稍有不同”。)

First of all, textContent whitespace representation is different from innerText one.

(首先, textContent空格表示与innerText不同。)

Second, and more importantly, textContent includes all of SCRIPT tag contents , whereas innerText doesn't.

(其次,更重要的是, textContent 包含所有SCRIPT标签内容 ,而innerText不包含。)

Just to make things more entertaining, Opera - besides implementing standard textContent - decided to also add MSHTML's innerText but changed it to act as textContent - ie including SCRIPT contents (in fact, textContent and innerText in Opera seem to produce identical results, probably being just aliased to each other).

(为了使事情更具娱乐性,Opera除了实现标准的textContent之外,还决定添加MSHTML的innerText 但将其更改为textContent ,即包括SCRIPT内容(实际上,Opera中的textContentinnerText似乎产生相同的结果,可能只是彼此混叠)。)

textContent is part of Node interface, whereas innerText is part of HTMLElement .

(textContentNode接口的一部分,而innerTextHTMLElement一部分。)

This, for example, means that you can "retrieve" textContent but not innerText from text nodes:

(例如,这意味着您可以从文本节点“检索” textContent而不是“ innerText ”:)

var el = document.createElement('p');
var textNode = document.createTextNode('x');

el.textContent; // ""
el.innerText; // ""

textNode.textContent; // "x"
textNode.innerText; // undefined

Finally, Safari 2.x also has buggy innerText implementation.

(最后,Safari 2.x还具有错误的innerText实现。)

In Safari, innerText functions properly only if an element is neither hidden (via style.display == "none" ) nor orphaned from the document.

(在Safari中,仅当元素既没有隐藏(通过style.display == "none" )也没有从文档中孤立出来时, innerText才能正常运行。)

Otherwise, innerText results in an empty string.

(否则, innerText导致一个空字符串。)

I was playing with textContent abstraction (to work around these deficiencies), but it turned out to be rather complex .

(我正在玩textContent抽象(以解决这些缺陷),但事实证明它相当复杂 。)

You best bet is to first define your exact requirements and follow from there.

(最好的选择是首先定义您的确切要求,然后从那里开始。)

It is often possible to simply strip tags off of innerHTML of an element, rather than deal with all of the possible textContent / innerText deviations.

(通常可以简单地从元素的innerHTML中剥离标签,而不是处理所有可能的textContent / innerText偏差。)

Another possibility, of course, is to walk the DOM tree and collect text nodes recursively.

(当然,另一种可能性是遍历DOM树并递归收集文本节点。)


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...