如何在动画函数中循环QuerySelectorall?

发布于 2025-01-26 20:28:41 字数 4935 浏览 3 评论 0原文

我正在尝试将动画应用于for循环中创建的所有图像,但是在for循环中创建的任何图像都没有显示任何动画,我尝试以多种方式尝试使用foreach和常规循环。从本质上讲,我想要的是制作它,以便在for循环中创建的10个图像可以具有与在屏幕上动画并像第一个图像一样工作的第一张图像相同的动画。请帮助,完整代码链接

https://code.sololearrearn .com/wwdw59oenfqb

const fps = 10;

const cats = [];
for (i = 0; i < 10; i++) {
  var img = document.createElement("img");
  img.setAttribute("src", "");
  img.className = "catSwarm"
  img.addEventListener('click', function handleClick(event) {
    change();
    clickCounter();


  });
  img.addEventListener('load', function handleClick(event) {

  })

  document.body.appendChild(img);
  cats.push(img)

}

let image = document.querySelector("img");
let angle = Math.PI / 2;
//store the previous time the animate function last fired
let prevTimeArg;

function animate(currentTimeParam) {


  if (prevTimeArg != null) {
    angle += (currentTimeParam - prevTimeArg) * 0.004;
  }
  // Setting the previous time to the time the function currently fires
  prevTimeArg = currentTimeParam;
  image.style.top = (Math.tan(angle) * 150) + "px";
  image.style.left = (Math.tan(angle) * 150) + "px";
  image.style.height = (Math.cos(angle) * 1000) + "px";
  image.style.width = (Math.cos(angle) * 1000) + "px";


  setTimeout(() => {
    requestAnimationFrame(currentTime => animate(currentTime));
  }, 0 / fps)
}

for (i = 0; i < cats.length; i++) {
  window.requestAnimationFrame(animate);
}

先感谢您。

I am trying to apply animation to all of the images created in a for loop, but none of the images created in the for loop are showing any animation, I have tried in multiple ways such as using forEach and a regular for loop. Essentially, what I want is to make it so the 10 images created prior in a for loop can have the same animation as the first image that is being animated across the screen and work like the first image. Please help, full code is linked here:

https://code.sololearn.com/Wwdw59oenFqB

const fps = 10;

const cats = [];
for (i = 0; i < 10; i++) {
  var img = document.createElement("img");
  img.setAttribute("src", "");
  img.className = "catSwarm"
  img.addEventListener('click', function handleClick(event) {
    change();
    clickCounter();


  });
  img.addEventListener('load', function handleClick(event) {

  })

  document.body.appendChild(img);
  cats.push(img)

}

let image = document.querySelector("img");
let angle = Math.PI / 2;
//store the previous time the animate function last fired
let prevTimeArg;

function animate(currentTimeParam) {


  if (prevTimeArg != null) {
    angle += (currentTimeParam - prevTimeArg) * 0.004;
  }
  // Setting the previous time to the time the function currently fires
  prevTimeArg = currentTimeParam;
  image.style.top = (Math.tan(angle) * 150) + "px";
  image.style.left = (Math.tan(angle) * 150) + "px";
  image.style.height = (Math.cos(angle) * 1000) + "px";
  image.style.width = (Math.cos(angle) * 1000) + "px";


  setTimeout(() => {
    requestAnimationFrame(currentTime => animate(currentTime));
  }, 0 / fps)
}

for (i = 0; i < cats.length; i++) {
  window.requestAnimationFrame(animate);
}

Thank you in advance.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

财迷小姐 2025-02-02 20:28:41

我会委派,如果这个想法是在单击时为猫动画,

您可以在动画中制作3个全局vars

const fps = 10;
const div = document.getElementById("catsContainer");
const cats = [];
for (let i = 0; i < 10; i++) {
  let img = document.createElement("img");
  img.setAttribute("src", "");
  img.className = "catSwarm"
  div.appendChild(img);
  cats.push(img)
}
let image;
let prevTimeArg;
let angle;
div.addEventListener('click', function handleClick(e) {



  image = e.target;
  angle = Math.PI / 2;
  //store the previous time the animate function last fired
  window.requestAnimationFrame(animate);
})

function animate(currentTimeParam) {


  if (prevTimeArg != null) {
    angle += (currentTimeParam - prevTimeArg) * 0.004;
  }
  // Setting the previous time to the time the function currently fires
  prevTimeArg = currentTimeParam;
  image.style.top = (Math.tan(angle) * 150) + "px";
  image.style.left = (Math.tan(angle) * 150) + "px";
  image.style.height = (Math.cos(angle) * 1000) + "px";
  image.style.width = (Math.cos(angle) * 1000) + "px";


  setTimeout(() => {
    requestAnimationFrame(currentTime => animate(currentTime));
  }, 0 / fps)
}
<div id="catsContainer"></div>

I would delegate, if the idea is to animate the cat on click

You can make 3 global vars to use in the animation

const fps = 10;
const div = document.getElementById("catsContainer");
const cats = [];
for (let i = 0; i < 10; i++) {
  let img = document.createElement("img");
  img.setAttribute("src", "");
  img.className = "catSwarm"
  div.appendChild(img);
  cats.push(img)
}
let image;
let prevTimeArg;
let angle;
div.addEventListener('click', function handleClick(e) {



  image = e.target;
  angle = Math.PI / 2;
  //store the previous time the animate function last fired
  window.requestAnimationFrame(animate);
})

function animate(currentTimeParam) {


  if (prevTimeArg != null) {
    angle += (currentTimeParam - prevTimeArg) * 0.004;
  }
  // Setting the previous time to the time the function currently fires
  prevTimeArg = currentTimeParam;
  image.style.top = (Math.tan(angle) * 150) + "px";
  image.style.left = (Math.tan(angle) * 150) + "px";
  image.style.height = (Math.cos(angle) * 1000) + "px";
  image.style.width = (Math.cos(angle) * 1000) + "px";


  setTimeout(() => {
    requestAnimationFrame(currentTime => animate(currentTime));
  }, 0 / fps)
}
<div id="catsContainer"></div>

物价感观 2025-02-02 20:28:41

您可以在函数animate中尝试此解决方案,您应该查询图像并在每个图像上应用动画:

function animate(currentTimeParam) {

    const images = document.getElementsByClassName('catSwarm')// <=== This is what you need

    for (var i = 0; i < images.length; i++) {
        const image = images[i]

        if (prevTimeArg != null) {
            angle += (currentTimeParam - prevTimeArg) * 0.004;
        }
        // Setting the previous time to the time the function currently fires
        prevTimeArg = currentTimeParam;
        image.style.top = (Math.tan(angle) * 150) + "px";
        image.style.left = (Math.tan(angle) * 150) + "px";
        image.style.height = (Math.cos(angle) * 1000) + "px";
        image.style.width = (Math.cos(angle) * 1000) + "px";


        setTimeout(() => {
            requestAnimationFrame(currentTime => animate(currentTime));
        }, 0 / fps)
    }

}

window.requestAnimationFrame(animate);

You can try this solution, inside the function animate, you should query your images and apply the animation on each image:

function animate(currentTimeParam) {

    const images = document.getElementsByClassName('catSwarm')// <=== This is what you need

    for (var i = 0; i < images.length; i++) {
        const image = images[i]

        if (prevTimeArg != null) {
            angle += (currentTimeParam - prevTimeArg) * 0.004;
        }
        // Setting the previous time to the time the function currently fires
        prevTimeArg = currentTimeParam;
        image.style.top = (Math.tan(angle) * 150) + "px";
        image.style.left = (Math.tan(angle) * 150) + "px";
        image.style.height = (Math.cos(angle) * 1000) + "px";
        image.style.width = (Math.cos(angle) * 1000) + "px";


        setTimeout(() => {
            requestAnimationFrame(currentTime => animate(currentTime));
        }, 0 / fps)
    }

}

window.requestAnimationFrame(animate);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文