table自动滚动效果


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style type="text/css">
        .table {
          width: 100%;
          left: 30%;
          border-collapse: collapse;
          border-spacing: 0;
        }
        .fixedThead {
          display: block;
          width: 100%;
        }
        .scrollTbody {
          display: block;
          height: 316px;
          overflow: hidden;
          width: 100%;
        }
        .table td {
          width: 300px;
          border-bottom: #333 1px dashed;
          padding: 5px;
          background-color: #ddd;
        }
        .table th {
          width: 300px;
          border-bottom: #333 1px dashed;
          border-top: #333 1px dashed;
          padding: 5px;
          line-height: 24px;
          background-color: #cfc;
        }
        .table tr {
          border-bottom: #333 1px dashed;
          line-height: 24px;
          padding: 5px;
        }
        thead.fixedThead tr th:last-child {
          color: #ff0000;
        }
      </style>
         <script language="JavaScript">
            //先在table的最后增加一行,然后再把第一行中的数据填充到新增加的行中,最后再删除table的第一行
            function change(table) {
              var row = table.insertRow(table.rows.length); //在table的最后增加一行,table.rows.length是表格的总行数
              for (j = 0; j < table.rows[0].cells.length; j++) {
                //循环第一行的所有单元格的数据,让其加到最后新加的一行数据中(注意下标是从0开始的)
                var cell = row.insertCell(j); //给新插入的行中添加单元格
                cell.height = "24px"; //一个单元格的高度,跟css样式中的line-height高度一样
                cell.innerHTML = table.rows[0].cells[j].innerHTML; //设置新单元格的内容,这个根据需要,自己设置
              }
              table.deleteRow(0); //删除table的第一行
            }
            function tableInterval() {
              var table = document.getElementById("test"); //获得表格
              change(table); //执行表格change函数,删除第一行,最后增加一行,类似行滚动
            }
            setInterval("tableInterval()", 2000); //每隔2秒执行一次change函数,相当于table在向上滚动一样
          </script>
</head>
<!-- <body> -->
    <body align="center">
        <h1 style="font-color: blur">滚动表格</h1>
        <table class="table" align="center">
          <thead class="fixedThead" align="center">
            <tr>
              <th>姓名</th>
              <th>性别</th>
              <th>年龄</th>
            </tr>
          </thead>
          <tbody id="test" class="scrollTbody" align="center">
            <tr>
              <td>张三</td>
              <td>男</td>
              <td>18</td>
            </tr>
            <tr>
              <td>李四</td>
              <td>男</td>
              <td>20</td>
            </tr>
            <tr>
              <td>王昕</td>
              <td>女</td>
              <td>19</td>
            </tr>
            <tr>
              <td>李佳</td>
              <td>女</td>
              <td>21</td>
            </tr>
            <tr>
              <td>张三</td>
              <td>男</td>
              <td>18</td>
            </tr>
            <tr>
              <td>李四</td>
              <td>男</td>
              <td>20</td>
            </tr>
            <tr>
              <td>王昕</td>
              <td>女</td>
              <td>19</td>
            </tr>
            <tr>
              <td>李佳</td>
              <td>女</td>
              <td>21</td>
            </tr>
            <tr>
              <td>张三</td>
              <td>男</td>
              <td>18</td>
            </tr>
            <tr>
              <td>李四</td>
              <td>男</td>
              <td>20</td>
            </tr>
            <tr>
              <td>王昕</td>
              <td>女</td>
              <td>19</td>
            </tr>
            <tr>
              <td>李佳</td>
              <td>女</td>
              <td>21</td>
            </tr>
            <tr>
              <td>张三</td>
              <td>男</td>
              <td>18</td>
            </tr>
            <tr>
              <td>李四</td>
              <td>男</td>
              <td>20</td>
            </tr>
            <tr>
              <td>王昕</td>
              <td>女</td>
              <td>19</td>
            </tr>
            <tr>
              <td>李佳</td>
              <td>女</td>
              <td>21</td>
            </tr>
            <tr>
              <td>张三</td>
              <td>男</td>
              <td>18</td>
            </tr>
            <tr>
              <td>李四</td>
              <td>男</td>
              <td>20</td>
            </tr>
            <tr>
              <td>王昕</td>
              <td>女</td>
              <td>19</td>
            </tr>
            <tr>
              <td>李佳</td>
              <td>女</td>
              <td>21</td>
            </tr>
            <tr>
              <td>张三</td>
              <td>男</td>
              <td>18</td>
            </tr>
            <tr>
              <td>李四</td>
              <td>男</td>
              <td>20</td>
            </tr>
            <tr>
              <td>王昕</td>
              <td>女</td>
              <td>19</td>
            </tr>
            <tr>
              <td>李佳</td>
              <td>女</td>
              <td>21</td>
            </tr>
            <tr>
              <td>张三</td>
              <td>男</td>
              <td>18</td>
            </tr>
            <tr>
              <td>李四</td>
              <td>男</td>
              <td>20</td>
            </tr>
            <tr>
              <td>王昕</td>
              <td>女</td>
              <td>19</td>
            </tr>
            <tr>
              <td>李佳</td>
              <td>女</td>
              <td>21</td>
            </tr>
          </tbody>
        </table>
      </body>
    
<!-- </body> -->
</html>

### 实现 a-table 组件中的自动滚动 在 Ant Design Vue 的 `a-table` 组件中实现自动滚动效果,可以通过监听特定事件并调用浏览器原生的滚动方法来完成。具体来说,在某些情况下触发时(例如加载新数据),可以让表格容器自动滚动到指定位置。 对于 `a-table` 自动滚动的需求,通常有以下几种场景: #### 场景一:初次渲染完成后自动滚到底部 如果希望当表格首次加载完毕后立即滚动至底部显示最新记录,则可以在 mounted 生命周期钩子内操作 DOM[^1]。 ```javascript mounted() { this.$nextTick(() => { const tableBody = document.querySelector('.ant-table-body'); if (tableBody) { setTimeout(() => { // 延迟执行以确保DOM已更新 tableBody.scrollTop = tableBody.scrollHeight; }, 0); } }); } ``` #### 场景二:动态添加新行时保持最后一条可见 每当向表格追加新的行项之后,应该让新增的数据始终处于视图范围内。这同样依赖于对 `.ant-table-body` 元素的操作,并结合 Vue 的响应式特性处理数据变化后的回调逻辑[^2]. ```vue <template> <div ref="scrollContainer"> <!-- 表格代码 --> </div> </template> <script setup lang="ts"> import { nextTick, onMounted } from 'vue'; const props = defineProps({ dataSource: Array, }); watchEffect(async () => { await nextTick(); scrollToBottom(); }); function scrollToBottom() { const container = $refs.scrollContainer as HTMLElement; if (!container) return; container.scrollTop = container.scrollHeight; } onMounted(scrollToBottom); // ...其他业务逻辑... </script> ``` 需要注意的是,上述方案假设表格被包裹在一个具有固定高度且允许垂直溢出 (`overflow-y`) 的父级容器里;否则即使设置了 scrollTop ,也可能因为没有足够的空间而无法看到实际的效果。 此外,还可以考虑通过设置 CSS 样式属性如 `max-height`, `overflow:auto|scroll` 来控制表格的高度和滚动行为,从而更好地配合 JavaScript 进行动态调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值