首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么innerHTML和textContent给出了不同的结果?

为什么innerHTML和textContent给出了不同的结果?
EN

Stack Overflow用户
提问于 2021-10-20 16:15:01
回答 1查看 258关注 0票数 1

我知道这两个属性的工作方式不同。根据规范,innerHTML处理html标记,而textContent处理文本。但我不明白他们为什么在这里这样工作。

代码语言:javascript
复制
//textContent
function func1() {
    let a3 = [[1, 2, 3], [3, 4, 5], [6, [7, 'my']]];
    document.querySelector('.out-1').textContent = a3[2][0][1];
}
document.querySelector('.b-1').onclick = func1;

//innerHTML
function func2() {
    let a3 = [[1, 2, 3], [3, 4, 5], [6, [7, 'my']]];
    document.querySelector('.out-2').innerHTML = a3[2][0][1];
    return a3[2][1][1];
}
document.querySelector('.b-2').onclick = func2;
代码语言:javascript
复制
.wrapper {
  margin-bottom: 50px;
}
代码语言:javascript
复制
 <!-- textContent -->
 <div class='wrapper'>
   <div>textContent</div>
   <button class="b-1">PUSH</button>
   <div class="out-1"></div>
 </div>
 
 <!-- innerHTML -->
<div class='wrapper'>
   <div>innerHTML</div>
   <button class="b-2">PUSH</button>
   <div class="out-2"></div>
</div>

我试着找出不存在的元素。textContent什么也不做,而innerHTMLundefined。为什么是这样?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-10-20 16:25:34

问题-

  • a321;返回未定义的元素,因为没有这样的元素。innerHTML显示未定义但textContent将未定义的字符串视为空字符串

代码语言:javascript
复制
const o = document.getElementById('1');
const s = document.getElementById('2');

o.textContent = undefined;
s.innerHTML = undefined;

console.log(typeof o.textContent);
// this means undefined is treated as an empty string
代码语言:javascript
复制
<div id="1"></div>
<div id="2"></div>

注:

根据我测试的内容,innerHTML接受对象、数组、字符串、数字、布尔值、未定义等等的任何内容,它将显示对象、数组等,除非为null,否则innerHTML将将其解析为空内容,而不会显示任何内容。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69649603

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档