2 回答

TA貢獻1795條經驗 獲得超7個贊
wall_reply_text
最可能的解釋是當這段代碼運行時沒有類名的元素,所以document.getElementsByClassName('wall_reply_text')
返回一個空數組。當您嘗試訪問該空數組中的索引 0 時,您會得到undefined
,因此在嘗試訪問時會出現錯誤undefined.textContent
。

TA貢獻1871條經驗 獲得超13個贊
如果沒有元素,則需要中斷
var n = 0, comment=""
while (true) {
const div = document.getElementsByClassName('wall_reply_text')[n]
if (div) comment = div.textContent;
else break
if (comment.indexOf("публикации") == 0) {
console.log(n,comment);
}
n++;
}
<div class="wall_reply_text">1</div>
<div class="wall_reply_text">публикации</div>
<div class="wall_reply_text">3</div>
<div class="wall_reply_text">4</div>
這是一種更優雅的方式
[...document.querySelectorAll('.wall_reply_text')]
.map(div => div.textContent)
.forEach((comment,i) => {
if (comment.indexOf("публикации") == 0) {
console.log(i,comment);
}
})
<div class="wall_reply_text">1</div>
<div class="wall_reply_text">публикации</div>
<div class="wall_reply_text">3</div>
<div class="wall_reply_text">публикации</div>
如果您只需要一個索引,則可以選擇
const comments = [...document.querySelectorAll('.wall_reply_text')]
.map(div => div.textContent)
console.log(comments.indexOf("публикации"))
<div class="wall_reply_text">1</div>
<div class="wall_reply_text">публикации</div>
<div class="wall_reply_text">3</div>
<div class="wall_reply_text">4</div>
添加回答
舉報