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

时间:2023-09-19 23:20:37

开头说下innerText和outerText只在chrome浏览器中有效

定义和用法

innerHTML 属性设置或返回表格行的开始和结束标签之间的 HTML,包括标签。

来看代码

js 中innerHTML,innerText,outerHTML,outerText的区别
<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head> <body>
<div id="div1">这是一个标签div</div>
<span id="span1">这是一个标签span</span>
<div id="div2">
<span>div2里面的span1</span>
<span>div2里面的span2</span>
</div>
<script>
var div1 = document.getElementById("div1").innerHTML;
var span1 = document.getElementById("span1").innerHTML;
var div2 = document.getElementById("div2").innerHTML;
console.log(div1);
console.log(span1);
console.log(div2);
</script>
</body> </html>
js 中innerHTML,innerText,outerHTML,outerText的区别

我定义了三个标签 ,然后用console打印出来

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

可以看出如果如果当前标签只有文字,那innerHTML只会输出文字

如果还有子标签存在,则会将子标签以及标签内的文字一起输出,这点一定要切记

这个时候你可以用replace方法来将标签去除

只获得文本内容

document.getElementById('div2').innerHTML.replace(/<.+?>/gim,''));

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

如上,span标签已经没有了,只剩下里面的文本内容

定义和用法

innerText 属性设置或返回表格行的开始和结束标签之间的 HTML内容,不包括Html标签。
我们看代码
js 中innerHTML,innerText,outerHTML,outerText的区别
<body>
<div id="div1">这是一个标签div</div>
<span id="span1">这是一个标签span</span>
<div id="div2">
<span>div2里面的span1</span>
<span>div2里面的span2</span>
<img src="" alt="">
</div>
<script>
var div1 = document.getElementById("div1").innerText;
var span1 = document.getElementById("span1").innerText;
var div2 = document.getElementById("div2").innerText;
console.log(div1);
console.log(span1);
console.log(div2); </script>
</body>
js 中innerHTML,innerText,outerHTML,outerText的区别
 打印出来的结果
js 中innerHTML,innerText,outerHTML,outerText的区别

从结果可以看到不管是当前标签还是子标签都只输出文本内容

定义和用法

outerHTML  设置或获取对象及其内容的HTML形式,也就是标签和文本内容全都显示出来
我们看代码
js 中innerHTML,innerText,outerHTML,outerText的区别
<body>
<div id="div1">这是一个标签div</div>
<span id="span1">这是一个标签span</span>
<div id="div2">
<span>div2里面的span1</span>
<span>div2里面的span2</span>
<img src="" alt="">
</div>
<script>
var div1 = document.getElementById("div1").outerHTML;
var span1 = document.getElementById("span1").outerHTML;
var div2 = document.getElementById("div2").outerHTML;
console.log(div1);
console.log(span1);
console.log(div2);
</script>
</body>
js 中innerHTML,innerText,outerHTML,outerText的区别

我们看控制台的打印结果

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

有意思吧

outerHTML是把当前标签的全部内容包括标签本身也全部取出来了

定义和用法

outerText  设置或获取对象及其内容的HTML形式,也就是标签和文本内容全都显示出来

我们来看代码

js 中innerHTML,innerText,outerHTML,outerText的区别
<body>
<div id="div1">这是一个标签div</div>
<span id="span1">这是一个标签span</span>
<div id="div2">
你好世界
<span>div2里面的span1</span>
<span>div2里面的span2</span>
<img src="" alt="">
</div>
<script>
var div1 = document.getElementById("div1").outerText;
var span1 = document.getElementById("span1").outerText;
var div2 = document.getElementById("div2").outerText;
console.log(div1);
console.log(span1);
console.log(div2);
</script>
</body>
js 中innerHTML,innerText,outerHTML,outerText的区别

看console打印的结果

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

很显然,outerText是把当前标签的内容给输出了,如果有子标签,也会把子标签的内容也一起输出了

那好,经过这么一比较,我们就可以得出结论了

innerHTML  输出当前标签的文本内容,如果标签内有子标签,会连子标签本身和子标签内的文本内容一起输出

innerText     只输出当前标签内的文本内容,如果标签内有子标签,那么也只输出子标签内的文本内容

outerHTML  输出当前标签的本身和标签内的文本内容,如果有子标签,那么子标签本身和标签内的文本内容也将一起输出

outerText     只输出当前标签内的文本内容,如果标签内有子标签,那么也只输出子标签内的文本内容