【问题标题】:clearInterval in loop don't work as expected循环中的 clearInterval 不能按预期工作
【发布时间】:2022-01-09 18:17:03
【问题描述】:

我有问题 当我删除字母时,单词仍然存在

我有两个 h1,我从每个 h1 中删除单词,当所有字母都被删除时,我专门为每个 h1 停止间隔

let mySelector = document.querySelectorAll(".writ-text");
for (let l = 0; l < mySelector.length; l++) {

  removeText = setInterval(function() {

    // Cut the last letter of the word and print the word after editing
    document.querySelectorAll(".writ-text")[l].textContent =
      document.querySelectorAll(".writ-text")[l].textContent.substr(0,
        document.querySelectorAll(".writ-text")[l].textContent.length - 1);

    // Check if the entire word has been deleted
    if (document.querySelectorAll(".writ-text")[l].textContent.length == 0) {
      clearInterval(removeText)
    }
  }, 1000);
}
<h1 class="writ-text">gold</h1>
<h1 class="writ-text">golder</h1>

【问题讨论】:

  • 请改用const removeText =。目前removeText 正在成为一个全局变量,因此每次迭代都会覆盖之前的赋值。添加const(或let)使其范围保持在for循环块

标签: javascript html for-loop clearinterval


【解决方案1】:

您已经清除了唯一一个名为 removeText(global scoped) 的 setInterval,它适用于两个文本。
使用像 let const 这样的块作用域来锻炼

let mySelector = document.querySelectorAll(".writ-text");
for (let l = 0; l < mySelector.length; l++) {

 let removeText = setInterval(function() {

    // Cut the last letter of the word and print the word after editing
    document.querySelectorAll(".writ-text")[l].textContent =
      document.querySelectorAll(".writ-text")[l].textContent.substr(0,
        document.querySelectorAll(".writ-text")[l].textContent.length - 1);

    // Check if the entire word has been deleted
    if (document.querySelectorAll(".writ-text")[l].textContent.length == 0) {
      clearInterval(removeText)
    }
  }, 1000);
}
<h1 class="writ-text">gold</h1>
<h1 class="writ-text">golder</h1>

【讨论】:

  • this 在您的回调中指的是 window / 全局对象(而不是间隔 id)。这只有效,因为间隔永远不会被清除
  • 是的,您必须使用 Nick Parsons 所说的块范围变量,@user16733810
  • 你是怎么用的?
  • 尝试阅读以下文章:const & let
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2022-12-17
  • 2021-10-25
  • 2017-03-12
  • 2019-07-09
  • 1970-01-01
相关资源
最近更新 更多