DOM中的outerHTML,innerHTML,outerText,innerText的区别

时间:2023-03-09 20:36:55
DOM中的outerHTML,innerHTML,outerText,innerText的区别

--转自http://blog.163.com/yw_0721/blog/static/7164579720102932157759/

简单的说innerHTML和outerHTML、innerText与outerText的不同之处在于:

1)、innerHTML与outerHTML在设置对象的内容时包含的HTML会被解析,而innerText与outerText则不会。 
2)、在设置时,innerHTML与innerText仅设置标签内的文本,而outerHTML与outerText设置包括标签在内的文本。

DOM中的outerHTML,innerHTML,outerText,innerText的区别

特别说明: 
  innerHTML是符合W3C标准的属性,而innerText、outerText、outerHTML只适用于IE浏览器,因此,尽可能地去使用innerHTML,而少用innerText,如果要输出不含HTML标签的内容,可以使用innerHTML取得包含HTML标签的内容后,再用正则表达式去除HTML标签,下面是一个简单的符合W3C标准的示例: 
<a href="javascript:alert(document.getElementById('test').innerHTML.replace(/<.+?>/gim,''))">无HTML,符合W3C标准</a>

详细出处参考:http://jhxk.javaeye.com/blog/353309

代码练习:(ie生效,ff中只有innerHTML是对的)

<script   type="text/javascript">
function getinnerHTML()
{
var e=window.document.getElementById("testdiv");
alert(e.innerHTML); //<p>白云</p>
}
function getouterHTML()
{
var e=window.document.getElementById("testdiv");
alert(e.outerHTML); //<div id="testdiv"><p>白云</p></div>
}
function getinnerText()
{
var e=window.document.getElementById("testdiv");
alert(e.innerText); //白云
}
function getouterText()
{
var e=window.document.getElementById("testdiv");
alert(e.outerText); //白云
}
</script> <div id="testdiv"><p>白云</p></div>
<p>
<input type="button" name="Submit2" value="innerHTML" onClick="getinnerHTML()">
<input type="button" name="Submit" value="outerHTML" onClick="getouterHTML()">
<input type="button" name="Submit2" value="innerHTML" onClick="getinnerText() ">
<input type="button" name="Submit2" value="innerHTML" onClick="getouterText()">
</p>