用JS如何制作列表循环播放的效果

Admin 2022-08-06 群英技术资讯 492 次浏览

在实际应用中,我们有时候会遇到“用JS如何制作列表循环播放的效果”这样的问题,我们该怎样来处理呢?下文给大家介绍了解决方法,希望这篇“用JS如何制作列表循环播放的效果”文章能帮助大家解决问题。




本文实例为大家分享了js实现列表自动滚动循环播放的具体代码,供大家参考,具体内容如下

1.实现效果图

鼠标移入,暂停滚动; 鼠标移出,继续滚动;

2.原理

  • 要实现无缝衔接,在原有ul后面还要有一个一样内容的ul;
  • 最外层div为可视区域,设overflow:hidden;
  • 2个ul的高度 > 外层可视div高度,才能滚动;

3.实现代码

html:

<!-- vue -->
<div id="review_box" @mouseover="rollStop()" @mouseout="rollStart(60)">
    <ul id="comment1">
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
    </ul>
    <ul id="comment2"></ul>
</div>

css:

div {
    height: 100px; /* 必须 */
    overflow: hidden;/* 必须 */
}

js:

//vue data
data (){
    return {
        timer: null,
    }
},
mounted() {
      this.roll(60);
},
beforeDestroy() {
      if (this.timer) clearInterval(this.timer);
},
//vue methods
roll(t) {
    var ul1 = document.getElementById("comment1");
    var ul2 = document.getElementById("comment2");
    var ulbox = document.getElementById("review_box");
    ul2.innerHTML = ul1.innerHTML;
    ulbox.scrollTop = 0;
    this.rollStart(t);
},
rollStart(t) {
    var ul1 = document.getElementById("comment1");
    var ul2 = document.getElementById("comment2");
    var ulbox = document.getElementById("review_box");
    this.rollStop();
    this.timer = setInterval(()=>{
        // 当滚动高度大于列表内容高度时恢复为0
        if (ulbox.scrollTop >= ul1.scrollHeight) {
            ulbox.scrollTop = 0;
        } else {
            ulbox.scrollTop++;
        }
    }, t);
},
rollStop(){
    clearInterval(this.timer);
},

以上就是关于“用JS如何制作列表循环播放的效果”的介绍了,感谢各位的阅读,如果大家想要了解更多相关的内容,欢迎关注群英网络,小编每天都会为大家更新不同的知识。
群英智防CDN,智能加速解决方案

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

猜你喜欢

成为群英会员,开启智能安全云计算之旅

立即注册
专业资深工程师驻守
7X24小时快速响应
一站式无忧技术支持
免费备案服务
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
在线客服
微信公众号
返回顶部
返回顶部 返回顶部
在线客服
在线客服