var text = dom.innerText || dom.textContent;
<p id="dom">一段文字内容<span style="position:absolute;">...</span></p>
一段文字内容…
position:absolute
avec <span>
défini... sont étroitement liés au contenu du texte précédent, sans aucun espace avant et après. <p>Cependant, lorsque nous avons obtenu les valeurs id="dom"
et <p>
de l'élément innerText
de textContent
respectivement, quelque chose d'intéressant s'est produit. La valeur de retour de innerText
est en fait apparue devant. DotDian. un espace. <p>Comme le montre la capture d'écran ci-dessous : <p><p>innerText
et textContent
montrent des différences, voir c'est croire, vous pouvez cliquer ici : Démo comparative de la différence entre innerText et textContent<p>Pourquoi y a-t-il une telle différence ? <p> est en fait innerText
qui conserve les propriétés de saut de ligne des éléments de niveau bloc et se présente sous la forme de sauts de ligne. En HTML, si white-space
n'est pas pre
ou pre-wrap
, il apparaîtra sous forme d'espace. C'est-à-dire que les espaces dans l'image ci-dessous sont en fait des sauts de ligne : <p><p> Par exemple, si nous définissons l'élément parent white-space:pre
pour restituer le résultat, l'effet montré dans l'image ci-dessous apparaîtra. : <p><p> Dans cet exemple, bien que l'élément <span>
soit un élément en ligne, la valeur calculée de position:absolute
devient <🎜 due. au réglage de display
>, par conséquent, bien qu'il n'y ait pas de saut de ligne visuellement, des sauts de ligne sont toujours générés lorsque block
est obtenu, ce qui entraîne des espaces. innerText
<p>2. Différence de règle : s'il faut obtenir des éléments cachés On sait qu'il y a le morceau de HTML suivant : <p><p id="dom2">我后面有一段隐藏文字<span hidden>,就是我啦!</span></p>
dom2.innerText
sera également visible, comme le montre la figure suivante : dom2.textContent的
<p>Comme vous peut voir, l'élément <p> ne peut pas être utilisé display:none
obtenu, mais innerText
peut, que l'élément soit caché ou non. textContent
Vous pouvez cliquer ici : <p>Démo de comparaison des différences entre innerText et textContent<p>3. Différences de règles en termes de performances et de redistribution<p>此外,由于innerText
属性值的获取会考虑CSS样式,因此读取innerText
的值将触发回流以确保计算出的样式是最新的,而回流在计算上很昂贵,会降低性能,因此应尽可能避免回流。而textContent
只是单纯读取文本内容,因此性能更高。<p>4. IE浏览器不符合上面规则<p>但是在IE浏览器下,innerText
的表现和规范是不符的,最终表现为textContent
属性一样的效果,也就是没有空格,也不会不显示隐藏元素,例如下面IE11下的效果截图:<p><p>另外,与textContent
不同,在Internet Explorer(版本11及以下)中更改innerText
将从元素中移除子节点,并永久销毁所有子文本节点。不可能再将节点插入任何其他元素或同一元素中。<p>三、最后的结论<p>innerText
由于存在诸多特别的特性、以及兼容性差异,以及性能方面问题,以及实际开发的需求的考量,不推荐使用,推荐使用textContent
获取文本内容。var text = dom.textContent;
var text = dom.textContent || dom.innerText;
innerText
包含的细节这么多。innerHTML
是高频使用属性,没想到原本以为相对应也会高频使用的innerText
居然这么有故事,地位被textContent
取代了,就像小说里的故事一样,总是出乎意料。
<p>另外,如果你要在一个DOM元素中改变文字内容,推荐使用textContent
,而不是innerHTML
,性能会更高一点。
<p>好了,就说这么多,一个小小的研究,希望能够对大家的学习有所帮助。
<p>原文地址:https://www.zhangxinxu.com/wordpress/?p=8941
<p>本文来自 js教程 栏目,欢迎学习!Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!