你可能知道,获取和设置 DOM 元素内部文本可以用这两个属性:Node.textContent 和 Element.innerText。
乍一看,它们似乎做着完全相同的事情,但它们之间有一些微妙但重要的区别。今天,我们来看看它们的作用,以及它们的异同之处。
废话不说,直接看代码。
相同之处
比如下面这个 DOM 元素。
I love a good tuna sandwich!
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;
如果元素内部还有其他标签,它们都会忽略。
I love a good tuna sandwich!
- // returns "I love a good tuna sandwich!"
- let textHTML1 = sandwich.textContent;
- // also returns "I love a good tuna sandwich!"
- let textHTML2 = sandwich.innerText;
另外,这两个属性都能用于设置元素内部文本。
- // 替换文本
- //
Hello, world!
- sandwich.textContent = 'Hello, world!';
- // 也可以追加
- //
Hello, world! And hi, Universe!
- sandwich.innerText += ' And hi, Universe!';
不同之处
看上去做着同样的事情,那么它们有什么区别?
举个例子就清楚了。
This is not rendered.
Hello world!
- 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译站公众号。
当前题目:知道这两个DOM属性区别的,头发应该不多了吧?
标题路径:http://www.mswzjz.cn/qtweb/news6/341506.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能