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

為了賬號安全,請及時綁定郵箱和手機立即綁定

為什么要在第一個定時器 遍歷subMenuEles,然后remove active屬性?

// 根據教程視頻,active 屬性不是加給 subMenuEles 中的li,而是加個一級導航的li;

// 那為什么要做下面的操作?

this.timer1 = setTimeout(() => {

????this.subMenuEles.forEach((item) => {

????????item.classList.remove("active")

????})

})

正在回答

1 回答

//?定義類
class?Menu?{
????//?構造函數
????constructor?(id)?{
????????//?獲取?id為?menu-box?的標簽
????????this.box?=?document.querySelector(id);
????????//?獲取?menu-box?第一個?ul?標簽
????????this.ul?=?this.box.querySelector("ul");
????????//?獲取?menu-box?所有?li?標簽
????????this.lis?=?this.box.querySelectorAll("li");
????????//?獲取?menu-box?所有?class?為?sub-menu?的標簽
????????this.subMenuEles?=?this.box.querySelectorAll(".sub-menu");

????????this.timer1?=?null;
????????this.timer2?=?null;
????????this.init();
????}

????init?()?{
????????this.lis.forEach((item)?=>?{
????????????item.addEventListener("mouseenter",(e)?=>?{
????????????????let?li?=?e.target;
????????????????if?(this.timer1?!=?null)?{
????????????????????clearTimeout(this.timer1);
????????????????}
????????????????this.timer1?=?setTimeout(()?=>?{
????????????????????li.children[1].classList.add("active");
????????????????},?200)
????????????})
????????});


????????this.lis.forEach((item)?=>?{
????????????item.addEventListener("mouseleave",?(e)?=>?{
????????????????let?li?=?e.target;

????????????????if?(this.timer2?!=?null)?{
????????????????????clearTimeout(this.timer2);
????????????????}
????????????????this.timer2?=?setTimeout(()?=>?{
????????????????//?如果快速移動,li.childeren[1].classList.remove("active")
????????????????//?會因為上面的判斷而沒有執行,所以會出現鼠標移開但是二級列表還顯示的問題
????????????????//?鼠標離開后,遍歷二級列表,把二級列表的classList中的active去掉?
????????????????????this.subMenuEles.forEach((item)?=>?{
????????????????????????item.classList.remove("active")
????????????????????});????????
??????????????????????????????
????????????????????//?li.children[1].classList.remove("active");
????????????????},?200)
????????????})
????????});




????}


}


0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

為什么要在第一個定時器 遍歷subMenuEles,然后remove active屬性?

我要回答 關注問題
微信客服

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

幫助反饋 APP下載

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

公眾號

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