innerText和textContent很多人会困惑,因为都可以用来获取文本内容,实际上,两者还是有很多区别的,本文就将介绍这两个属性的异同,希望可以对大家的学习有所帮助。

一、之前错误的认识

innerText IE6就开始支持,那个时候,Firefox浏览器是不支持这个API的,一直到2016年3月份Firefox 45+才开始支持。

而textContent IE9浏览器才开始支持:

由于存在兼容性,因此在开发PC端项目的时候获取元素的文本内容都是下面的语句:var text = dom.innerText || dom.textContent;

久而久之,就误认为innerText和textContent作用是一样的。

最近一次实践突然让我发现,娘啊,原来innerText和textContent是有区别的,这种区别小萌新反而容易知道(因为会疑惑为何会有两个API),而我这样深受兼容性问题影响的大叔反而注意不到(以为是IE的文本获取API和Firefox的文本获取API互相支持)。

究竟区别在哪里呢?我们看几个例子就知道了。

二、innerText和textContent的不同

不同之一,调用对象不同。innerText只有HTML元素才可以调用,但是textContent任意Node节点都可以:HTMLElement.innerText和Node.textContent。

不同之二,值获取规则不同。

1. 规则差异之块级元素与换行符

已知有下面一段HTML:

一段文字内容...

实时效果如下:一段文字内容…

可以看到设置了position:absolute的元素里面的点点点...和前面的文字内容是紧密连接在一起的,前后没有任何空格。

但是,当我们分别获取id="dom"的

元素的innerText和textContent值的时候,有意思的事情发生了,innerText的返回值居然在点点点前面出现了一个空格。

如下截图所示:

innerText和textContent表现出了不同,眼见为实,您可以狠狠地点击这里:innerText和textContent区别对比demo

为什么会有这样的差异呢?

实际上是innerText会保留块级元素的换行特性,以换行符形式呈现。在HTML中,如果white-space不是pre或pre-wrap则会表现为空格。也就是下图中的空格实际上是换行符:

例如,我们设置呈现结果的父元素white-space:pre,则会出现下图所示的效果:

在本例中,虽然元素是内联元素,但由于设置了position:absolute使其display计算值变成了block,因此,虽然视觉上没有换行,但innerText获取的时候依旧产生了换行,导致空格出现。

2. 规则差异之隐藏元素的获取与否

已知有下面一段HTML:

我后面有一段隐藏文字,就是我啦!

此时,我们显示dom2.innerText和dom2.textContent的返回值,也会看出区别,如下图所示:

可以看到,display:none元素是无法使用innerText获取的,但是textContent却可以,无论元素隐藏与否。

3. 规则差异之性能与回流

此外,由于innerText属性值的获取会考虑CSS样式,因此读取innerText的值将触发回流以确保计算出的样式是最新的,而回流在计算上很昂贵,会降低性能,因此应尽可能避免回流。而textContent只是单纯读取文本内容,因此性能更高。

4. IE浏览器不符合上面规则

但是在IE浏览器下,innerText的表现和规范是不符的,最终表现为textContent属性一样的效果,也就是没有空格,也不会不显示隐藏元素,例如下面IE11下的效果截图:

另外,与textContent不同,在Internet Explorer(版本11及以下)中更改innerText将从元素中移除子节点,并永久销毁所有子文本节点。不可能再将节点插入任何其他元素或同一元素中。

三、最后的结论

innerText由于存在诸多特别的特性、以及兼容性差异,以及性能方面问题,以及实际开发的需求的考量,不推荐使用,推荐使用textContent获取文本内容。var text = dom.textContent;

如果你的项目还需要兼容IE8浏览器,则使用下面的代码:var text = dom.textContent || dom.innerText;

四、三言两语的结语

没想到innerText包含的细节这么多。innerHTML是高频使用属性,没想到原本以为相对应也会高频使用的innerText居然这么有故事,地位被textContent取代了,就像小说里的故事一样,总是出乎意料。

另外,如果你要在一个DOM元素中改变文字内容,推荐使用textContent,而不是innerHTML,性能会更高一点。

好了,就说这么多,一个小小的研究,希望能够对大家的学习有所帮助。

js text 和 html,JS DOM innerText和textContent的区别相关推荐

  1. js里html和text,JS DOM innerText和textContent的区别

    innerText和textContent很多人会困惑,因为都可以用来获取文本内容,实际上,两者还是有很多区别的,本文就将介绍这两个属性的异同,希望可以对大家的学习有所帮助. 一.之前错误的认识 in ...

  2. innerText和textContent的区别

    innerText和textContent的区别 设置文本替换时,两者都会把指定节点下的所有子节点也一并替换掉. textContent 会获取所有元素的内容,包括 <script> 和 ...

  3. day03_js学习笔记_03_js的事件、js的BOM、js的DOM

    day03_js学习笔记_03_js的事件.js的BOM.js的DOM ================================================================ ...

  4. 原生js和jquery常用的DOM操作

    前言 将原生JS和jquery里面的DOM操作进行了一下整理,方便以后温习. 创建元素节点 1.原生: document.createElement("div") 2.jquery ...

  5. js获取不到模板DOM元素

    在开发中遇到了一个问题,使用js一直获取不到dom元素..找了很久终于找到一个可行的方案: 代码如下: <script id='tpl_order_index_list' type='text/ ...

  6. html css廖雪峰,廖雪峰js教程笔记12 用DOM更新 innerHMTL 和修改css样式(示例代码)

    拿到一个DOM节点后,我们可以对它进行更新. 可以直接修改节点的文本,方法有两种: 一种是修改innerHTML属性,这个方式非常强大,不但可以修改一个DOM节点的文本内容,还可以直接通过HTML片段 ...

  7. JS操作iframe里的dom

    出自:http://www.css88.com/archives/2343 看到断桥残雪 对我上一篇日志的回复我也学习了一下JS操作iframe里的dom:主要参考了断桥残雪的<用JavaScr ...

  8. js学习笔记----JavaScript中DOM扩展的那些事

    什么都不说,先上总结的图~ Selectors API(选择符API) querySelector()方法 接收一个css选择符,返回与该模式匹配的第一个元素,如果没有找到匹配的元素,返回null. ...

  9. 解决webstorm调试js时Evaluate脚本获取dom属性丢失问题

    解决webstorm调试js时Evaluate脚本获取dom属性丢失问题,百思不得其解,最后找到,原因出在webstorm调用chrome调试接口时设置了一个"ownProperties&q ...

最新文章

  1. (十六)java springcloud版b2b2c社交电商spring cloud分布式微服务-使用spring cloud Bus刷新配置...
  2. java小程序例子_「小程序JAVA实战」java的聚合项目搭建(30)
  3. Node Mysql事务处理封装
  4. Android中build target,minSdkVersion,targetSdkVersion,maxSdkVersion概念区分
  5. 存储过程Procedure
  6. 2012服务器系统安装iis,Windows Server 2012服务器管理系统安装配置IIS8.5教程
  7. 江阴南菁高考2021高考成绩查询,江阴8所四星级高中高考成绩公布 南菁高中本一进线率达到了92.97%...
  8. java Excel导出 xlsx格式(超简单)
  9. 筛选出英语与计算机成绩之和,职称计算机和英语考试的成绩什么地方能够查到 – 手机爱问...
  10. SpringBoot --thymeleaf(资源文件css、js的引入)
  11. 【Low版】HAUT - OJ - Contest1035 - 2017届新生周赛(六)题解
  12. 【Netbackup恢复步骤-02】
  13. android 实体对象转 json,list转 json ,map转json
  14. 驱动人生6网卡版 v6.1.19.90 官方版
  15. redis 通道 java_【java】netty4,服务端向客户端主动发消息怎么把channel存储到redis缓存中?...
  16. kibana远端访问配置
  17. 【5G系列】MICO学习总结(2)
  18. python 统计文本字数 生成词云图
  19. 前端皮肤功能实现(基于Less)
  20. 带api的php探针,从零开始搭建前端监控系统(一)——web探针sdk

热门文章

  1. JSON补丁:JSON-P 1.1概述系列
  2. 使用Eclipse和Open Liberty的Java EE 8上的Java 9
  3. arrays.sort(._Arrays.sort与Arrays.parallelSort
  4. javafx11 最佳实践_JavaFX移动应用程序最佳实践,第1部分
  5. 如何使用Apache Drill分析高度动态的数据集
  6. SWT外观:自定义FlatScrollBar颜色等
  7. 如何使用Hibernate批处理DELETE语句
  8. 属性提取器:获取ListView即时更新其元素的最佳方法
  9. Oracle通过邀请Weaver和Chin推动JavaFX向前发展
  10. Java EE 7的高峰–使用EclipseLink的多租户示例