vue实现表格轮播

bash 复制代码
<template>
  <!-- 省略其他代码 -->
  <el-col :span="7">
    <div class="mb-20">
      <div class="station_box">
        <div class="show_title"><span class="title_name">焊接设备实时信息</span></div>
        <div class="height300" style="padding: 0px 15px;">
          <div class="infotb">
            <div class="disinline_block th tbcontent">
              <div class="name p11">机器人</div>
              <div class="p11">链接状态</div>
              <div class="p11">操作模式</div>
              <div class="p11">运行状态</div>
              <div class="p6">速度倍率</div>
              <div class="p11">加工节拍</div>
            </div>
            <!-- 修改这里:只显示currentRightTbData中的数据 -->
            <div class="disinline_block tbcontent" v-for="item in currentRightTbData" :key="item.name">
              <div class="name p11">{{ item.name }}</div>
              <div class="p11">{{ item.ljzhuangtai }}</div>
              <div class="p11">{{ item.moshi }}</div>
              <div class="p11">{{ item.yxzhuangtai }}</div>
              <div class="p11">{{ item.beilv }}</div>
              <div class="p11">{{ item.jiepai }}</div>
            </div>
          </div>
        </div>
      </div>
    </div>
  </el-col>
  <!-- 省略其他代码 -->
</template>

<script>
export default {
  name: 'bulletinboard',
  data() {
    return {
      // 省略其他数据...
      rightTbIndex: 0, // 当前显示的起始索引
      rightTbInterval: null, // 轮播定时器
    }
  },
  computed: {
    // 计算当前要显示的表格数据(每次两条)
    currentRightTbData() {
      const start = this.rightTbIndex;
      const end = Math.min(start + 2, this.righttbdata.length);
      return this.righttbdata.slice(start, end);
    }
  },
  beforeDestroy() {
    // 清除定时器
    if (this.rightTbInterval) {
      clearInterval(this.rightTbInterval);
    }
    // 省略其他清理代码...
  },
  mounted() {
    // 初始化轮播
    this.startRightTbCarousel();
    // 省略其他初始化代码...
  },
  methods: {
    // 启动右侧表格数据轮播
   startRightTbCarousel() {
            this.rightTbInterval = setInterval(() => {
                // 计算下一次的起始索引
                const nextIndex = this.rightTbIndex + 4;
                
                // 如果下一次会超出数据范围,则回到开头
                if (nextIndex >= this.righttbdata.length) {
                    this.rightTbIndex = 0;
                } else {
                    this.rightTbIndex = nextIndex;
                }
            }, 3000); // 每3秒切换一次
        },
    // 省略其他方法...
  }
}
</script>
bash 复制代码
rightTbIndex: 0, // 当前显示的起始索引
            rightTbInterval: null, // 轮播定时器
            righttbdata:[
                {
                    "name":"A",
                    "ljzhuangtai":"联机",
                    "moshi":"自动",
                    "yxzhuangtai":'待机',
                    "beilv":"100%",
                    "jiepai":"2651.35s",
                },
                {
                    "name":"B",
                    "ljzhuangtai":"联机",
                    "moshi":"自动",
                    "yxzhuangtai":'待机',
                    "beilv":"100%",
                    "jiepai":"2651.35s",
                },
                ]
相关推荐
1***s6322 分钟前
Vue图像处理开发
javascript·vue.js·ecmascript
一 乐13 分钟前
应急知识学习|基于springboot+vue的应急知识学习系统(源码+数据库+文档)
数据库·vue.js·spring boot
槁***耿19 分钟前
JavaScript在Node.js中的事件发射器
开发语言·javascript·node.js
一叶茶21 分钟前
移动端平板打开的三种模式。
前端·javascript
U***498327 分钟前
JavaScript在Node.js中的Strapi
开发语言·javascript·node.js
老前端的功夫1 小时前
前端浏览器缓存深度解析:从网络请求到极致性能优化
前端·javascript·网络·缓存·性能优化
颜酱3 小时前
Monorepo 架构以及工具选型、搭建
前端·javascript·node.js
X***48963 小时前
JavaScript在Node.js中的Nx
javascript·node.js·vim
o***Z4483 小时前
JavaScript在Node.js中的内存管理
开发语言·javascript·node.js
我命由我123454 小时前
微信开发者工具 - 模拟器分离窗口与关闭分离窗口
前端·javascript·学习·微信小程序·前端框架·html·js