innerText和innerHTML区别

innerText和innerHTML区别

尽管DOM带来了动态修改文档的能力,但对开发人员来说,这还不够。IE4.0为所有的元素引入了两个特性,以更方便的进行文档操作,这两个特性是innerText和innerHTML。
       其中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 &lt;div/&gt;.</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返回的不同值。

代码innerTextinnerHTML
<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;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值