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

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

使用 for 循環創建 JavaScript 中的特定 div 后,如何定位它們?

使用 for 循環創建 JavaScript 中的特定 div 后,如何定位它們?

一只斗牛犬 2023-07-06 15:09:26
由于這是一個 Etch-a-Sketch 剽竊,我需要能夠不按順序對 div 進行著色,但是,我設置的 for 循環會遍歷每個方塊,并在僅接觸其中一個方塊后將它們全部著色。JavaScript:const container = document.getElementById("container");        function makeRows (rows, columns) {        container.style.setProperty('--grid-rows', rows);        container.style.setProperty('--grid-cols', columns);        for (c = 0; c < (rows * columns); c++) {            let cell = document.createElement("div");            //cell.innerText = (c + 1);            container.appendChild(cell).className = "grid-item";        }        }        //Draw Board    makeRows(16, 16);        //Paint on board    const paint = document.querySelector("div.grid-item");            paint.addEventListener('mouseover', function(){            let paintBrush = document.getElementsByClassName('grid-item');                        for (let i = 0; i < paintBrush.length; i++)            {                paintBrush[i].style.backgroundColor = "black";            }            console.log("AHH HELP AHH");                });CSS::root {    --grid-cols: 0;    --grid-rows: 0;  }    #container {    display: grid;    padding: 10em;    height: 40vh;    width: 50vh;    margin-left: auto;    margin-right: auto;    grid-template-rows: repeat(var(--grid-rows), 1fr);    grid-template-columns: repeat(var(--grid-cols), 1fr);      }    .grid-item {    padding: 1em;    border: 1px solid #ddd;    text-align: center;  }
查看完整描述

1 回答

?
慕勒3428872

TA貢獻1848條經驗 獲得超6個贊

我認為您可以通過類名獲取所有元素(然后循環遍歷它們以單獨添加偵聽器。


請參閱下面的演示


const container = document.getElementById("container");


function makeRows(rows, columns) {

  container.style.setProperty('--grid-rows', rows);

  container.style.setProperty('--grid-cols', columns);

  for (c = 0; c < (rows * columns); c++) {

    let cell = document.createElement("div");

    //cell.innerText = (c + 1);

    container.appendChild(cell).className = "grid-item";

  }


}


//Draw Board

makeRows(16, 16);


//Paint on board

const paint = document.getElementsByClassName("grid-item");


for (var idx = 0; idx < paint.length; idx++) {

  paint[idx].addEventListener('mouseover', function() {

    this.style.backgroundColor = "black";

  });

}

:root {

  --grid-cols: 0;

  --grid-rows: 0;

}


#container {

  display: grid;

  padding: 10em;

  height: 40vh;

  width: 50vh;

  margin-left: auto;

  margin-right: auto;

  grid-template-rows: repeat(var(--grid-rows), 1fr);

  grid-template-columns: repeat(var(--grid-cols), 1fr);

}


.grid-item {

  padding: 1em;

  border: 1px solid #ddd;

  text-align: center;

}

<div id="container"></div>


查看完整回答
反對 回復 2023-07-06
  • 1 回答
  • 0 關注
  • 160 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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