vue 使用iView組件中的Table實(shí)現(xiàn)定時(shí)自動(dòng)滾動(dòng)效果
封裝Table
要在css中設(shè)置table的高度,使數(shù)據(jù)過(guò)多時(shí)出現(xiàn)滾動(dòng)條,將縱向設(shè)置為overflow-y: auto;橫向設(shè)置隱藏 overflow-x: hidden;
<template>
<div class="table_container">
<Table :loading="tableLoading" :columns="columns" :data="dataList" ref="tableL"></Table>
</div>
</template>
<script>
export default {
name: "tableList",
props: {
columns: {
type: Array,
default: () => []
},
dataList: {
type: Array,
default: () => []
},
},
data () {
return {
showContentHeight: 0,
tableBodyHeight: 0,
tableLoading: false,
}
},
methods: {
//動(dòng)態(tài)滾動(dòng)
dynamicScroll() {
let that = this
this.$nextTick(() => {
clearInterval(this.timer)
const table = this.$refs.tableL;
let tableBody = table.$el.__vue__.$refs.body;
if (tableBody) {
let showContentHeight = tableBody.offsetHeight;
let tableBodyHeight = tableBody.scrollHeight;
that.showContentHeight = showContentHeight
that.tableBodyHeight = tableBodyHeight
if(tableBodyHeight > showContentHeight) {
that.timerScroll()
}
}
});
},
//定時(shí)滾動(dòng)
timerScroll() {
let that = this
const tmpTimer = setInterval(() => {
const table = that.$refs.tableL;
let tableBody = table.$el.__vue__.$refs.body;
if (tableBody) {
let canScrollHeight = that.tableBodyHeight - that.showContentHeight
let scrollTop = tableBody.scrollTop
console.log('scrollTop', scrollTop)
scrollTop += that.showContentHeight;
if(scrollTop > canScrollHeight) {
scrollTop = canScrollHeight
}
tableBody.scrollTop = scrollTop;
}
}, 5 * 1000);
this.timer = tmpTimer
this.$once("hook:beforeDestroy", () => {
clearInterval(tmpTimer);
});
}
},
}
</script>
<style scoped lang="less">
.table_container {
height: 100%;
}
.table_container /deep/ .ivu-table-wrapper {
height: 100%;
border: none;
border-bottom: 0;
border-right: 0;
}
.table_container /deep/ .ivu-table-body {
height: calc(100% - 40px); //減掉表頭的高度
overflow-x: hidden;
overflow-y: auto;
}
.table_container /deep/ .ivu-table-column-center {
background-color: #39698D;
color: white;
}
.table_container /deep/ tbody .ivu-table-column-center {
color: #89D5EA;
}
.table_container /deep/ .ivu-table {
background-color:rgba(255,255,255, 0);
color: #89D5EA;
}
.table_container /deep/ .ivu-table td {
background-color:rgba(255,255,255, 0);
border-bottom: 1px solid #496893;
}
.table_container /deep/ .ivu-table-tip {
color: #89D5EA;
}
.table_container /deep/ .ivu-table:before,.table_container /deep/ .ivu-table:after {
background-color: rgba(255,255,255, 0);
}
.table_container /deep/ .ivu-table th {
border-bottom: none;
}
/** .ivu-table-body 滾動(dòng)條樣式*/
.table_container /deep/ .ivu-table-body::-webkit-scrollbar {
/*滾動(dòng)條整體樣式*/
width: 5px; /*高寬分別對(duì)應(yīng)橫豎滾動(dòng)條的尺寸*/
height: 3px;
}
.table_container /deep/ .ivu-table-body::-webkit-scrollbar-thumb {
/*滾動(dòng)條里面小方塊*/
border-radius: 10px;
height: 20px;
-webkit-box-shadow: inset 0 0 5px black;
}
.table_container /deep/ .ivu-table-body::-webkit-scrollbar-track {
/*滾動(dòng)條里面軌道*/
-webkit-box-shadow: inset 0 0 5px #6B90B6;
border-radius: 10px;
background: #ffffff;
}
</style>在引用組件的頁(yè)面調(diào)用定時(shí)滾動(dòng)方法
<template>
<div class="layout">
<table-list ref="tableList" :columns="columns" :data-list="warehouseList"/>
</div>
</template>
<script>
import { columns } from './config'
import tableList from "@/components/tableList";
export default {
name: "board",
components: {
tableList,
},
data () {
return {
columns,
warehouseList: [],
resultData: {},
}
},
mounted() {
this.getData()
},
methods: {
getData() {
getWarehouseList({}).then(res => {
console.log('getWarehouseList', res)
if(res.success) {
this.resultData = res.result
this.warehouseList = res.result.warehouseList
const tableList = this.$refs.tableList;
//動(dòng)態(tài)滾動(dòng)
tableList.dynamicScroll()
}
})
}
}
}
</script>
<style scoped lang="less">
.layout {
width: 100%;
height: 100%;
background:url("../../../assets/prod_board.png") no-repeat center -2px;
background-size: 100% 100%;
color: #fff;
}
</style>到此這篇關(guān)于vue 使用iView組件中的Table實(shí)現(xiàn)定時(shí)自動(dòng)滾動(dòng)的文章就介紹到這了,更多相關(guān)vue Table定時(shí)自動(dòng)滾動(dòng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue3應(yīng)用elementPlus table并滾動(dòng)顯示問(wèn)題
- vue3?el-table結(jié)合seamless-scroll實(shí)現(xiàn)表格數(shù)據(jù)滾動(dòng)的思路詳解
- vue中el-table兩個(gè)表尾合計(jì)行聯(lián)動(dòng)同步滾動(dòng)條實(shí)例代碼
- vue中獲取滾動(dòng)table的可視頁(yè)面寬度調(diào)整表頭與列對(duì)齊(每列寬度不都相同)
- vue elementUI table表格數(shù)據(jù) 滾動(dòng)懶加載的實(shí)現(xiàn)方法
- vue element-ui table表格滾動(dòng)加載方法
- vue iview 隱藏Table組件里的某一列操作
- Vue基于iview table展示圖片實(shí)現(xiàn)點(diǎn)擊放大
- 淺談vue的iview列表table render函數(shù)設(shè)置DOM屬性值的方法
相關(guān)文章
詳解vue-cli項(xiàng)目中用json-sever搭建mock服務(wù)器
這篇文章主要介紹了詳解vue-cli項(xiàng)目中用json-sever搭建mock服務(wù)器,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11
vue?結(jié)合webpack的初級(jí)使用指南小白學(xué)習(xí)篇
這篇文章主要為大家介紹了vue?結(jié)合webpack的初級(jí)使用指南非常適合入門(mén)webpack的小白學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05

