广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >vue实现列表无缝循环滚动
  • 373
分享到

vue实现列表无缝循环滚动

2024-04-02 19:04:59 373人浏览 泡泡鱼
摘要

本文实例为大家分享了Vue实现列表无缝循环滚动的具体代码,供大家参考,具体内容如下 功能介绍: 在PC端网页,包括大数据、官网、后台管理平台开发中,可能会用到这种列表循环滚动的展示。

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

功能介绍:

在PC端网页,包括大数据、官网、后台管理平台开发中,可能会用到这种列表循环滚动的展示。

大致需求:

1、列表可以使用数组循环遍历;

2、每隔几秒中列表数据向上滚动一定距离,展示下一条数据;

3、滚动到最后一条数据时重新显示第一条开始的数据(类似走马灯、banner图的循环效果);

整体思路:

1、使用两个定时器嵌套实现;

2、需要两个相同容器存放同样内容,实现无缝衔接效果;

效果展示:

完整代码:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <script src="https://unpkg.com/vue@2.6.14/dist/vue.min.js"></script>
        <style>
            
            .tableoOut {
                margin: 100px auto;
                width: 500px;
                height: 400px;
                background: pink;
                overflow: hidden;
                display: flex;
                align-items: center;
                justify-content: center;
                flex-direction: column;
            }
            .tableBox {
                width: 100%;
                background: #000;
                overflow: hidden
            }
            .tableTit {
                background: #000;
                width: 100%;
                height: 40px;
                color: #858A84;
                text-align: center;
                display: flex;
                justify-content: center;
                align-items: center;
            }
            .tableInner {
                height: auto;
            }
            .box {
                width: 100%;
                height: 50px;
                display: flex;
                justify-content: center;
                align-items: center;
                color: #fff;
            }
            .box .time {
                color: #858A84;
            }
            .tableoOut .addr, .tableoOut .time, .tableoOut .name {
                box-sizing: border-box;
                padding: 0 5px;text-align: center;
                overflow: hidden;
                white-space: nowrap;
                text-overflow: ellipsis;
            }
            .tableoOut .addr {
                width: calc(100% - 200px);
                flex-shrink: 0;
            }
            .tableoOut .name, .tableoOut .time {
                width: 100px;
                flex-shrink: 0;
            }
        </style>
    </head>
    <body>
        <div id="app">
            <div class="tableoOut" ref="tableoOut">
                <div class="tableTit">
                    <div class="name">姓名</div>
                    <div class="addr">地址</div>
                    <div class="time">入驻时间</div>
                </div>
                <div class="tableBox" ref="tableBox"
                    :style="{height: tableHei}">
                    <div class="tableInner" ref="tableInner">
                        <div class="box" v-for="item in 7" :key="item">
                            <div class="name">{{item}}</div>
                            <div class="addr">山东省山东省山东省山东省山东省山东省山东省山东省
                            山东省山东省山东省山东省山东省</div>
                            <div class="time">2022-05-26</div>
                        </div>
                    </div>
                    <div class="tableInner" v-if="size < 7">
                        <div class="box" v-for="item in 7" :key="item">
                            <div class="name">{{item}}</div>
                            <div class="addr">山东省山东省山东省山东省山东省山东省山东省山东省
                            山东省山东省山东省山东省山东省</div>
                            <div class="time">2022-05-26</div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </body>
    <script>
        new Vue({
            el: '#app',
            data: {
                tableHei: 'auto',
                timer: null,
                size: 0
            },
            mounted() {
                this.getTable();
            },
            methods: {
                getTable() {
                    const outHei = this.$refs.tableoOut.clientHeight - 60;
                    this.size = Math.floor(outHei / 50);
                    this.tableHei = this.size * 50 + 'px';
                    this.scrolls();
                },
                stepScroll() {
                    const step = 50;
                    let num = 0;
                    const tableBox = this.$refs.tableBox;
                    const stepTime = setInterval(function () {
                        num += 2;
                        if (num > step) {
                            num = 0;
                            clearInterval(stepTime);
                        } else {
                            tableBox.scrollTop += 2;
                        }
                    }, 20);
                },
                scrolls() {
                    const that = this;
                    const tableBox = this.$refs.tableBox;
                    const tableInner = this.$refs.tableInner;
                    clearInterval(this.timer);
                    this.timer = setInterval(function () {
                        if(tableBox.scrollTop === tableInner.scrollHeight) {
                            tableBox.scrollTop = 0;
                        }
                        that.stepScroll();
                    }, 2000);
                },
            }
        })
    </script>
</html>

setInterval踩坑:

发现这种方法实现的定时轮播,有一阵没访问页面,会出现卡停的情况,采用下面的解决方法:

<script>
    new Vue({
        el: '#app',
        data: {
            tableHei: 'auto',
            timer: null,
            size: 0,
            stopSign: true, // 判断定时器是否停止标识
            stepTime: null, // 改为全局定时器
        },
        mounted() {
            const that = this;
            // 增加浏览器激活状态判断。非激活状态为onblur
            window.onfocus = function(e) {
                const tableBox = that.$refs.tableBox;
                const sT = tableBox.scrollTop;
                console.log("激活状态!")
                if (!that.stopSign) {
                    tableBox.scrollTop = Math.round(sT / 50) * 50;
                    clearInterval(that.stepTime);
                }
            }
            this.getTable();
        },
        methods: {
            getTable() {
                const outHei = this.$refs.tableoOut.clientHeight - 60;
                this.size = Math.floor(outHei / 50);
                this.tableHei = this.size * 50 + 'px';
                this.scrolls();
            },
            stepScroll() {
                const that = this;
                const step = 50;
                let num = 0;
                const tableBox = this.$refs.tableBox;
                // 改为全局定时器,且在调用前先进行清空
                clearInterval(this.stepTime);
                this.stepTime = setInterval(function () {
                    that.stopSign = false;
                    num += 2;
                    if (num > step) {
                        num = 0;
                        clearInterval(that.stepTime);
                        that.stopSign = true;
                    } else {
                        tableBox.scrollTop += 2;
                    }
                }, 1000 / 60);
            },
            scrolls() {
                const that = this;
                const tableBox = this.$refs.tableBox;
                const tableInner = this.$refs.tableInner;
                clearInterval(this.timer);
                this.timer = setInterval(function () {
                    // 修改定时器结束判断条件
                    if(tableBox.scrollTop >= tableInner.scrollHeight) {
                        tableBox.scrollTop = 0;
                    }
                    that.stepScroll();
                }, 2000);
            },
        }
    })
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: vue实现列表无缝循环滚动

本文链接: https://www.lsjlt.com/news/34270.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue实现列表无缝循环滚动
    本文实例为大家分享了vue实现列表无缝循环滚动的具体代码,供大家参考,具体内容如下 功能介绍: 在PC端网页,包括大数据、官网、后台管理平台开发中,可能会用到这种列表循环滚动的展示。...
    99+
    2022-09-27
  • vue实现列表无缝滚动
    本文实例为大家分享了vue实现列表无缝滚动的具体代码,供大家参考,具体内容如下 HTML部分代码 <template> <div id="box" clas...
    99+
    2022-11-12
  • vue实现列表垂直无缝滚动
    本文实例为大家分享了vue实现列表垂直无缝滚动的具体代码,供大家参考,具体内容如下 实现新闻列表的轮播(如下图) 上代码 封装的so-marquee.vue <templat...
    99+
    2022-11-13
  • vue实现列表无缝滚动效果
    本文实例为大家分享了vue实现列表无缝滚动效果的具体代码,供大家参考,具体内容如下 1.安装 npm install vue-seamless-scroll --save 2.在需要...
    99+
    2022-11-13
  • vue怎么实现列表垂直无缝滚动
    这篇文章主要介绍“vue怎么实现列表垂直无缝滚动”,在日常操作中,相信很多人在vue怎么实现列表垂直无缝滚动问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue怎么实现列表垂直无缝滚动”的疑惑有所帮助!接下来...
    99+
    2023-06-29
  • vue实现公告消息横向无缝循环滚动
    本文实例为大家分享了vue实现公告消息横向无缝循环滚动的具体代码,供大家参考,具体内容如下 该组件实现了公告消息的无缝横向滚动。我命名为marqueex.vue文件,感谢原来博主的分...
    99+
    2022-11-13
  • vue或css动画实现列表向上无缝滚动
    本文实例为大家分享了vue或css动画实现列表向上无缝滚动的具体代码,供大家参考,具体内容如下 方法一:vue的实现方法 <div id="publishMain" clas...
    99+
    2022-11-13
  • js实现列表循环滚动
    本文实例为大家分享了js实现列表循环滚动的具体代码,供大家参考,具体内容如下 先介绍几个属性 clientHeight 元素的高度clientTop 元素顶部边框的宽度scrollT...
    99+
    2022-11-13
  • vue怎么实现公告消息横向无缝循环滚动
    这篇文章主要讲解了“vue怎么实现公告消息横向无缝循环滚动”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue怎么实现公告消息横向无缝循环滚动”吧!marqueex.vue<templ...
    99+
    2023-06-29
  • 基于vue实现循环滚动列表功能
    注意:需要给父容器一个height和:data='Array'和overfolw:hidden;左右滚动需要给ul容器一个初始化 css width。 先来介绍该组件的用法: 1.安...
    99+
    2022-11-12
  • vue或css怎么实现列表向上无缝滚动动画
    本篇内容主要讲解“vue或css怎么实现列表向上无缝滚动动画”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue或css怎么实现列表向上无缝滚动动画”吧!效果如下:方法一:vue的实现方法<...
    99+
    2023-06-29
  • JS如何实现无缝循环marquee滚动效果
    这篇文章主要介绍JS如何实现无缝循环marquee滚动效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!无缝循环marquee滚动JS代码实现,兼容IE, FireFox, Chro...
    99+
    2022-10-19
  • 怎么使用CSS3实现无限循环的无缝滚动
    小编给大家分享一下怎么使用CSS3实现无限循环的无缝滚动,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. 使用CSS3来实现若...
    99+
    2022-10-19
  • CSS3怎么实现无限循环的无缝滚动效果
    这篇文章主要讲解了“CSS3怎么实现无限循环的无缝滚动效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS3怎么实现无限循环的无缝滚动效果”吧!1. 使用CSS3来实现若要用CSS3的属...
    99+
    2023-07-05
  • jquery实现表格无缝滚动
    本文实例为大家分享了jquery实现表格无缝滚动的具体代码,供大家参考,具体内容如下 css部分我是用的弹性布局 *{ margin:0; ...
    99+
    2022-11-12
  • js如何实现列表循环滚动
    本篇内容主要讲解“js如何实现列表循环滚动”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“js如何实现列表循环滚动”吧!先介绍几个属性clientHeight 元素的高度clientTop 元素顶...
    99+
    2023-07-02
  • vue中使用vue-seamless-scroll插件实现列表无缝滚动效果
    需求:使用vue-seamless-scroll插件实现列表无缝滚动,也可以添加相应的点击跳转,点击事件会存在点击失效的问题。支持上下左右无缝滚动,单步滚动停留时间,以及水平方向的手...
    99+
    2022-11-13
  • vue实现无限消息无缝滚动
    本文实例为大家分享了vue实现无限消息无缝滚动的具体代码,供大家参考,具体内容如下 一、html <div class="table_box">    <div c...
    99+
    2022-11-13
  • ElementUItable无缝循环滚动的示例代码
    恰好实习的时候遇到了这个需求,而且网上的代码有点僵硬,所以我改了改,顺手水一篇博客出来。 部分思路来源:https://blog.csdn.net/qq_38543537/artic...
    99+
    2022-11-13
    ElementUI table无缝循环滚动 ElementUI table滚动
  • 如何使用CSS3实现无限循环的无缝滚动效果
    这篇文章将为大家详细讲解有关如何使用CSS3实现无限循环的无缝滚动效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 使用CSS3来实现若要用CSS3的属性实现的话,...
    99+
    2022-10-19
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作