javascript textContent与innerText的异同分析


Posted in Javascript onOctober 22, 2010

textContent与innerText的不同

IE下有个innerText属性,FF下有个textContent属性。很多以前给IE写脚本的,在FF下找不到innerText属性,于是网上搜到的建议是用textContent来替代。反之给FF写脚本的也一样。

但是实际上,这里有个误解。网上很多文章说“FF下等效于innerText属性的属性是textContent”————但是事实上并非如此。innerText与textContent有几点很重要的不同,导致它们在一些情况下不能直接互换使用。

前些日子写了个代码高亮JS插件,在IE下工作完全正常,而在FF下就不对头。在IE下使用的是innerText属性,而在FF下使用的则是textContent属性。在进行字符串处理的时候二者的不同导致了完全不一样的结果。于是就专门写了点东西来测试二者的不同。

根据测试的结果表明:
innerText:它的内容实际上就是你在浏览器看到的内容。它的值是经过浏览器解释过的结果:它将元素的innerHTML换码、解释,最终显示出来,然后去除各种格式信息留下的纯文本。它会把<br/>换成换行符,会将多个空格并成一个空格对待,而本来的换行符却并不会引起换行,IE会将其当作一个普通的单词边界(一般是空格)。再说的形象点,一个元素的innerText属性的值,和你将这个元素内容复制粘贴到记事本里的内容一致。

textContent:它的内容则是innerHTML去除所有标签后的内容(我怀疑这个是从XMLDOM中照搬过来的属性,特性完全一致)。它会将innerHTML中的转义字符(<、 什么的)进行换码,但是不对任何html标签进行解释,而是直接剔除它们。它也不会对innerHTML中的文本按照HTML的方式进行格式转换,比如多个空格还会原原本本地保留,不会合并为一个空格,换行符仍然存在(相反<br/>却不会导致换行)。

更加简练的总结:IE中的innerText是需要对innerHTML的值进行:
1、HTML转义(等同于XML转义,对<、&等转义字符进行处理);
2、经过HTML解释和CSS样式解释;
3、之后又剔除格式信息
之后留下的纯文本。
而FF中的textContent没有2、3步,在经过了HTML转义之后直接剔除所有html标签后得到的纯文本。

一个例子:

<div id=”T1″> 
ABCD 
EFG HIJ<br/>KLM  N 
OPQ<div>RS</div>T 
T 
<div>

这个id为T1的div,
在IE中的innerText属性的值为:
ABCD EFG HIJ 
KLM N OPQ 
RS 
T T

而在FF中的textContent的属性的值为:
(这里有个换行) 
ABCD 
EFG HIJKLM N 
OPQRST 
T

注意那个div中还嵌套了个div,而这个更能反映IE的innerText和FF的textContent各自的处理方式的不同:
div是块(block)元素,默认会独占一行,因此,在IE中的innerText反映为上述div中的RS独占一行,而FF的textContent完全不理会HTML格式,因此其textContent中的RS是和其它字符连在一起的,不会独占一行。

如果想更进一步,看看这个有趣的结果:
假如给里面那个div加一个style=”float:left;”,那么这个div就会由块元素变化为行元素,不再独占一行,因此IE的innerText属性中RS便不再独占一行,而与其它字符连在一起,而在FF中由于textContent不理会标签更不会理会CSS,因此它的textContent属性的值不会有任何变化。

这么看来,很多网上说的“让FF支持innerText属性”云云,其实都是多多少少有问题的。要实现IE的innerText,远没有想象中的那么简单,你若要使用JavaScript让FF拥有和innerText完全一样的效果,得自己把html标签属性全部parse一遍,解释它们,甚至还需要去解释css……
(不过根据原理,貌似通过剪贴板的复制和取回操作可以在FF下模拟innerText效果(这个未测试),但是1有副作用,2FF下的剪贴板操作也很麻烦。)

不过还好,大多数时候我们并不需要那么精确,使用innerHTML做点简单的处理即可达到比较接近的效果了。

注:以上代码均在IE6和FF3下完成测试。

Javascript 相关文章推荐
javascript 判断中文字符长度的函数代码
Aug 27 Javascript
js自动下载文件到本地的实现代码
Apr 28 Javascript
JavaScript获取当前网页标题(title)的方法
Apr 03 Javascript
javascript字符串与数组转换汇总
May 26 Javascript
jQuery中each()、find()和filter()等节点操作方法详解(推荐)
May 25 Javascript
Javascript中arguments对象的详解与使用方法
Oct 04 Javascript
老生常谈jquery id选择器和class选择器的区别
Feb 12 Javascript
解决layui前端框架 form表单,table表等内置控件不显示的问题
Aug 19 Javascript
在LayUI图片上传中,解决由跨域问题引起的请求接口错误的方法
Sep 24 Javascript
javascript/jquery实现点击触发事件的方法分析
Nov 11 jQuery
vue实现点击出现操作弹出框的示例
Nov 05 Javascript
Vue常用API、高级API的相关总结
Feb 02 Vue.js
js各种验证文本框输入格式(正则表达式)
Oct 22 #Javascript
JavaScript学习点滴 call、apply的区别
Oct 22 #Javascript
Web 前端设计模式--Dom重构 提高显示性能
Oct 22 #Javascript
jQuery中add实现同时选择两个id对象
Oct 22 #Javascript
jquery下动态显示jqGrid以及jqGrid的属性设置容易出现问题的解决方法
Oct 22 #Javascript
为jQuery.Treeview添加右键菜单的实现代码
Oct 22 #Javascript
使用jQuery模板来展现json数据的代码
Oct 22 #Javascript
You might like
php xml 入门学习资料
2011/01/01 PHP
基于PHP开发中的安全防范知识详解
2013/06/06 PHP
PHP图片水印类的封装
2017/07/06 PHP
PHP新特性之字节码缓存和内置服务器
2017/08/11 PHP
Jsonp 跨域的原理以及Jquery的解决方案
2010/05/18 Javascript
JavaScript父子窗体间的调用方法
2015/03/31 Javascript
js实现的动画导航菜单效果代码
2015/09/10 Javascript
Javascript中匿名函数的调用与写法实例详解(多种)
2016/01/26 Javascript
BootStrap中按钮点击后被禁用按钮的最佳实现方法
2016/09/23 Javascript
微信小程序 地图(map)实例详解
2016/11/16 Javascript
JS 拦截全局ajax请求实例解析
2016/11/29 Javascript
深入理解Javascript箭头函数中的this
2017/02/13 Javascript
正则 js分转元带千分符号详解
2017/03/08 Javascript
推荐三款不错的图片压缩上传插件(webuploader、localResizeIMG4、LUploader)
2017/04/21 Javascript
javaScript产生随机数的用法小结
2018/04/21 Javascript
微信公众平台获取access_token的方法步骤
2019/03/29 Javascript
利用node.js开发cli的完整步骤
2020/12/29 Javascript
python使用电子邮件模块smtplib的方法
2016/08/28 Python
python基础练习之几个简单的游戏
2017/11/10 Python
使用python进行文本预处理和提取特征的实例
2018/06/05 Python
Python中的groupby分组功能的实例代码
2018/07/11 Python
Python使用try except处理程序异常的三种常用方法分析
2018/09/05 Python
pyqt5让图片自适应QLabel大小上以及移除已显示的图片方法
2019/06/21 Python
Selenium+Python 自动化操控登录界面实例(有简单验证码图片校验)
2019/06/28 Python
python实现控制电脑鼠标和键盘,登录QQ的方法示例
2019/07/06 Python
python3实现斐波那契数列(4种方法)
2019/07/15 Python
浅谈pandas.cut与pandas.qcut的使用方法及区别
2020/03/03 Python
python 实现波浪滤镜特效
2020/12/02 Python
使用CSS3中的calc()属性来以算式表达尺寸数值
2016/06/06 HTML / CSS
巴西本土电商平台:Americanas
2020/06/21 全球购物
如何通过 CSS 写出火焰效果
2021/03/24 HTML / CSS
群众路线批评与自我批评
2014/02/06 职场文书
远程研修随笔感言
2014/02/10 职场文书
2014年商场国庆节活动策划方案
2014/09/16 职场文书
派出所班子党的群众路线对照检查材料思想汇报
2014/10/01 职场文书
Java版 简易五子棋小游戏
2022/05/04 Java/Android