温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

两个DOM属性区别有哪些

发布时间:2021-10-19 11:23:30 来源:亿速云 阅读:133 作者:iii 栏目:web开发

本篇内容介绍了“两个DOM属性区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

相同之处

比如下面这个 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;

“两个DOM属性区别有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

dom
AI