知道这两个 DOM 属性区别的,头发应该很少了吧?

你可能知道,获取和设置 DOM 元素内部文本能够用这两个属性:Node.textContent 和 Element.innerTextcss

乍一看,它们彷佛作着彻底相同的事情,但它们之间有一些微妙但重要的区别。今天,咱们来看看它们的做用,以及它们的异同之处。code

废话不说,直接看代码。class

相同之处

好比下面这个 DOM 元素。渲染

<p id="sandwich">I love a good tuna sandwich!</p>

Node.textContent 和Element.innerText属性都能获取#sandwich 元素内部的文本。im

let sandwich = document.querySelector('#sandwich');

// returns "I love a good tuna sandwich!"
let text1 = sandwich.textContent;

// also returns "I love a good tuna sandwich!"
let text2 = sandwich.innerText;

若是元素内部还有其余标签,它们都会忽略。img

<p id="sandwich">I love a good <strong>tuna</strong> sandwich!</p>
// returns "I love a good tuna sandwich!"
let textHTML1 = sandwich.textContent;

// also returns "I love a good tuna sandwich!"
let textHTML2 = sandwich.innerText;

另外,这两个属性都能用于设置元素内部文本。di

// 替换文本
// <p id="sandwich">Hello, world!</p>
sandwich.textContent = 'Hello, world!';

// 也能够追加
// <p id="sandwich">Hello, world! And hi, Universe!</p>
sandwich.innerText += ' And hi, Universe!';

不一样之处

看上去作着一样的事情,那么它们有什么区别?键盘

  • Node.textContent 属性获取所有文本内容,包括元素内部那些未渲染到页面的内容。
  • Element.innerText 只返回渲染出来的文本,相似于能够用光标和键盘选中的文本部分。

举个例子就清楚了。loading

<div class="greeting">
	<style type="text/css">
		p {
			color: rebeccapurple;
		}
	</style>
	<p hidden>This is not rendered.</p>
	<p>Hello world!</p>
</div>
let greeting = document.querySelector('.greeting');

/* 返回 
p {color: rebeccapurple;} 
This is not rendered. 
Hello world!
*/
let text1 = greeting.textContent;

// 返回 "Hello world!"
let text2 = greeting.innerText;

这下总算知道区别了!又躺学了一个知识点~query

本文首发于公众号 1024译站