Почему при создании drag&drop появляется ошибка box.addEventListener is not a function

Мне нужно сделать драгндорп для нескольких изображений. Я написал код, он работает только для одного изображения.

const box = document.querySelector("#box")

const offset = {
  x: null,
  y: null
};

const getPosition = (e) => {
  const pageX =
    e.clientX + document.body.scrollLeft + document.documentElement.scrollLeft;
  const pageY =
    e.clientY + document.body.scrollTop + document.documentElement.scrollTop;

  return {
    pageX,
    pageY
  };
};

const mousemoveHandler = (e) => {
  const { pageX, pageY } = getPosition(e);
  box.style.left = pageX - offset.x + "px";
  box.style.top = pageY - offset.y + "px";
};

const mousedownHandler = (e) => {
  const { pageX, pageY } = getPosition(e);
  const { x, y } = box.getBoundingClientRect();
  const leftOffset = pageX - x;
  const topOffset = pageY - y;
  offset.x = leftOffset;
  offset.y = topOffset;
  window.addEventListener("mousemove", mousemoveHandler);
  box.classList.add("active");
};

const mouseupListener = async () => {
  window.removeEventListener("mousemove", mousemoveHandler);
  box.classList.remove("active");
  offset.x = null;
  offset.y = null;
};

box.addEventListener("mousedown", mousedownHandler);
window.addEventListener("mouseup", mouseupListener);

Если я меняю document.querySelector("#box") на document.querySelectorAll("box"), то появляется ошибка Uncaught TypeError: box.addEventListener is not a function.

Понимаю, что сейчас возвращается массив элементов, но возникает вопрос как вернуть событие для каждого элемента.


Ответы (0 шт):