微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

我对轮播,setInterval和style.transform =“ translateX”有问题

如何解决我对轮播,setInterval和style.transform =“ translateX”有问题

我不明白为什么该功能在必须显示一个计数器时才起作用,并且如果我要求她翻译一个元素,那么她只能翻译一次。

这是代码,我尝试了很多,但是找不到解决方法

var i; //  set your counter to 1
var numberOfImages = document.getElementsByClassName("imgs").length;
var imgWidth = window.innerWidth;
    
console.log(numberOfImages);
    
var startIt = setInterval(function() {
    document.getElementById("carouselTrain").style.transform = "translateX(" + -imgWidth + "px)";
    document.getElementById("carouselTrain").style.transitionDuration = "0.5s";
    document.getElementById("carouselTrain").style.transform = "translateX(" + -imgWidth + "px)";
    document.getElementById("carouselTrain").style.transitionDuration = "0.5s";        
},1000);

解决方法

问题是您每次都用相同的值进行翻译。翻译不会累积,这就是为什么您看不到任何更改的原因。

如果您在设置间隔功能中更新imgWidth的值,您将开始看到一些操作。在setInterval函数的底部执行此操作:

imgWidth += imgWidth

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。