Satrol_ 2022-11-11 12:52 采纳率: 100%
浏览 9
已结题

蓝桥杯标签跳转问题var转let

先问一下let为什么写var失效了
感觉和let订死区间没什么关系求解


// 实现选项卡功能
function init() {
  // TODO 待补充代码
  var tabs = document.getElementsByClassName("tabs")[0].children
  var card = document.getElementById("content").children
  for (let index = 0; index < tabs.length; index++) {
    tabs[index].onclick = function () {
      for (let j = 0; j < tabs.length; j++) {
        tabs[j].classList.remove("active")
        card[j].classList.remove("active")
      }
      tabs[index].classList.add("active")
      card[index].classList.add("active")
    }
  }
}
init();


  • 写回答

1条回答 默认 最新

  • 黛琳ghz 2022年度博客之星前端领域TOP 8 2022-11-11 15:14
    关注

    var是函数作用域,而let是块作用域。在函数内声明了var,整个函数内都是有效的,在for循环内定义了一个var变量,实际上其在for循环以外也是可以访问的,而let由于是块作用域,所以如果在块作用域内(for循环内)定义的变量,在其外面是不可被访问的。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月19日
  • 已采纳回答 11月11日
  • 创建了问题 11月11日