人工智能

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

时间:2010-12-5 17:23:32  作者:应用开发   来源:IT科技类资讯  查看:  评论:0
内容摘要:你可能知道,获取和设置 DOM 元素内部文本可以用这两个属性:Node.textContent 和 Element.innerText。乍一看,它们似乎做着完全相同的事情,但它们之间有一些微妙但重要的

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

乍一看,别的不多它们似乎做着完全相同的应该事情,但它们之间有一些微妙但重要的知道区别。今天,性区我们来看看它们的别的不多作用,以及它们的应该异同之处。服务器托管

废话不说,知道直接看代码。性区

相同之处

比如下面这个 DOM 元素。别的不多

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

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

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; 

如果元素内部还有其他标签,知道它们都会忽略。性区

<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; 

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

// 替换文本 // <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 只返回渲染出来的文本,类似于可以用光标和键盘选中的文本部分。

举个例子就清楚了。

<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; 

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

本文转载自微信公众号「1024译站」,可以通过以下二维码关注。转载本文请联系1024译站公众号。

copyright © 2025 powered by 益强资讯全景  滇ICP备2023006006号-31sitemap