亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

無法讀取 JavaScript 中未定義的屬性“textContent”

無法讀取 JavaScript 中未定義的屬性“textContent”

繁星點點滴滴 2023-04-20 10:26:00
問題是什么?我聲明了變量 nvar n = 0;while (true) {  var comment = document.getElementsByClassName('wall_reply_text')[n].textContent;    if (comment.indexOf("публикации") == 0) {    alert(comment);  }    n++;}
查看完整描述

2 回答

?
一只萌萌小番薯

TA貢獻1795條經驗 獲得超7個贊

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



查看完整回答
反對 回復 2023-04-20
?
慕桂英4014372

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>


查看完整回答
反對 回復 2023-04-20
  • 2 回答
  • 0 關注
  • 123 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號