手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >innerText和innerHTML 一些问题分析
innerText和innerHTML 一些问题分析
摘要:其中innerText特性用来修改起始标签和结束标签之间的文本的。例如,假设有个空的元素,希望将其变成Newtextforthediv.。用...

其中innerText特性用来修改起始标签和结束标签之间的文本的。例如,假设有个空的<div/>元素,希望将其变成<div>New text for the div.</div>。用DOM实现时,要这么做:

oDiv.appendChild(document.createTextNode("New text for the div."));

这段代码并不难读,但是很冗长。如果使用innerText,只要这么做:

oDiv.innerText = "New text for the div.";

使用innerText,代码更加简洁,并且更容易理解。另外,innerText会自动将小于号、大于号、引号和&符号进行HTML编码,所有是毫不需当心特殊字符:

oDiv.innerText = "New text for the <div/>.";

这一行代码的执行结果是<div>New text for the <div/>.</div>。但如何一定要再元素中包含HTML标签呢?这就是innerHTML所要解决的问题。

应用innerHTML特性,可以直接给元素分配HTML字符串,而不需考虑使用DOM方法来创建元素。例如,假设一个空<div/>要变成<div><strong>Hello</strong><em>World</em></div>。使用DOM,要用下面的代码:

var oStrong = document.createElement("strong');

oStrong.appendChild(document.createTextNode("hello"));

var oEm = document.createElement("em");

oEm.appendChild(document.createTextNode("World"));

oDiv.appendChild(oStrong);

oDiv.appendChild(document.createTextNode(""));

oDiv.appendChild(oEm);

而使用innerHTML,代码就变成:

oDiv.innerHTML = "<strong>Hello</strong><em>World</em>";

七行代码一下就变成一行,这就是innerHML的威力!

还可以使用innerText和innerHTML来获取元素的内容。如果元素只包含文本,那么innerText和innerHTML返回相同的值。但是,如果同时包含文本和其他元素,innerText将只返回文本的表示,而innerHTML,将返回所有元素和文本的HTML代码。下面的表格列出了根据特定代码innerText和innerHTML返回的不同值。

代码 innerText innerHTML
<div>Hello world</div> "Hello world" "Hello world"
<div><b>Hello</b>world</div> "Hello world" "<b>Hello</b>world"
<div><span></span></div> "" "<span></span>"
后,通过将innerText赋值给它自身,表示从指定的元素中删除所有的HTML标签。

oDiv.innerText = oDiv.innerText;

【innerText和innerHTML 一些问题分析】相关文章:

textarea是否自动换行

js+HTML5基于过滤器从摄像头中捕获视频的方法

javascript匹配车牌号正则表达式

AspNet中使用JQuery上传插件Uploadify详解

JQuery中DOM事件合成用法实例分析

JQuery中DOM事件冒泡实例分析

JavaScript对传统文档对象模型的支持

js对象和json对象互相转换的问题

谈一谈javascript中继承的多种方式

在JavaScript中使用JSON数据

精品推荐
分类导航