【发布时间】:2021-12-07 11:43:03
【问题描述】:
我知道这两个属性的工作方式不同。根据规范,innerHTML 适用于 html-tags,而textContent 适用于文本。但我不明白他们为什么在这里工作。
//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;
.wrapper {
margin-bottom: 50px;
}
<!-- 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 什么都没有,而innerHTML 却没有undefined。为什么会这样?
【问题讨论】:
-
这能回答你的问题吗? stackoverflow.com/questions/35213147/…
-
"
textContent设置器的步骤是,如果给定值为 null,则将其视为空字符串..."我> -
@Andreas 这不是
null。这是undefined -
@Ivan 在 DOM 中没有
undefined这样的东西。我非常有信心undefined在到达 DOM 时被视为“null”。
标签: javascript html innerhtml