网站首页 > 知识剖析 正文
场景
我是需要在table最后添加一行数据,然后把滚动条滚动到最后。
查网上的解决方案都是读取html结构,暴力的去获取,虽能解决问题,但是不喜欢这种打补丁的解决方案,我想着官方应该有相关的定义,于是就去看table的定义。
技术栈
我用的是vue3+ts+elment-plus。elment-plus的table提供了滚动的方法`setScrollTop`,但是api上没找到获取数据列高度的方法,于是我就F12看table的类型定义,发现了一个`$ref`属性,打印出来一看,上面竟然定义了各个层级的对象。
于是我就获取各个对象的高度看看哪个是我需要的。
一开始我就打印tableWrapper.height,发现不对,打印这个对象,发现高度是可视区域的高度。
又打印tableBody.height的高度,发现获取不到,结果发现了`scrollHeight`,看数值对了。
代码如下:
<el-table
ref="singleTableRef"
:data="list"
border
style="width: 100%"
height="500px"
>
... 列的定义
</el-table>
// 滚动设置
const onScrollBottom = () => {
// 我上面还有其他的处理,所以我放到了nextTick中
nextTick(() => {
// 解决方法
singleTableRef.value?.setScrollTop(singleTableRef.value?.$refs.tableBody.scrollHeight)
})
}
轻松搞定!
猜你喜欢
- 2024-12-25 uni-app入门理论知识 uni-app入门到实战
- 2024-12-25 公开招标=轴承滚动体厂齿箱滚子生产线厂房东侧通道维修项目
- 2024-12-25 vue实现滑块拖拽校验 vue滑动条
- 2024-12-25 Vue中如何实现列表动画 vue 动画示例
- 2024-12-25 2022年最好的10个JavaScript动画库
- 2024-12-25 MacOS 如何选择鼠标不飘滚动平滑 mac鼠标滑轮上下滚动设置
- 2024-12-25 新版Chrome浏览器如何使用网页滚动截图
- 2024-12-25 10个滚动到底部自动加载插件 10个滚动到底部自动加载插件是什么
- 2024-12-25 前端特效 | 如何制作一个彩虹滚动进度条?
- 2024-12-25 滚动图标——手机图标随着手势滚动,让你的桌面动起来
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)