使用 translate3d 实现轮播图时如何解决最后一页切换到第一页时的闪动问题?(闪动.第一页.如何解决.切换到.translate3d.....)
wufei123 2025-01-05 阅读:4 评论:0轮播图轮回切换时的闪动问题
在使用 translate3d 来实现轮播图时,在最后一页切换到第一页时,如果您切换较慢,可能会出现图片闪动的问题。
这是因为在切换的时候,transition 的过渡时间还在继续,如果鼠标点击很快,图片会瞬间跳到下一张,不会等到过渡结束。因此,会出现图片闪动的情况。
解决方案
您可以修改 changeCur 方法来解决这个问题。解决方案如下:
changeCur(add){ // this.out.style.setProperty('--trans', 'transform'); this.con.style.transitionDuration = '.3s'; //切换cur方法 let cur = this.out.style.getPropertyValue('--cur'); cur = parseInt(cur); if(add){ // this.setCur(cur+1); // if(cur > this.num-1){ // setTimeout(() => { // // cur = 1; // // this.out.style.setProperty('--trans', 'none'); // this.con.style.transitionDuration = '0s'; // this.setCur(1); // }, 300) // } if (cur === this.num) { this.con.style.transitionDuration = '0s'; this.setCur(0); this.con.offsetWidth; this.con.style.transitionDuration = '.3s'; this.setCur(1); } else { this.setCur(cur + 1); } } else{ // this.setCur(cur-1); // if(cur < 2){ // // setTimeout(() => { // // // cur = this.num; // // // this.out.style.setProperty('--trans', 'none'); // // this.con.style.transitionDuration = '0s'; // // this.setCur(this.num); // // }, 300) // } if (cur === 1) { this.con.style.transitionDuration = '0s'; this.setCur(this.num + 1); this.con.offsetWidth; this.con.style.transitionDuration = '.3s'; this.setCur(this.num); } else { this.setCur(cur - 1); } } }
以上就是使用 translate3d 实现轮播图时如何解决最后一页切换到第一页时的闪动问题?的详细内容,更多请关注知识资源分享宝库其它相关文章!
版权声明
本站内容来源于互联网搬运,
仅限用于小范围内传播学习,请在下载后24小时内删除,
如果有侵权内容、不妥之处,请第一时间联系我们删除。敬请谅解!
E-mail:dpw1001@163.com
发表评论