element的el-table中記錄滾動(dòng)條位置的示例代碼
場(chǎng)景重現(xiàn):在項(xiàng)目中使用了keep-alive來(lái)緩存組件,且使用element中的table列表,但在項(xiàng)目中是對(duì)table進(jìn)行了二次封裝,跟頁(yè)碼合在了一起。按照網(wǎng)上的直接對(duì)scrollTop賦值,賦值失敗了,還要加上setTimeout才能成功,雖然實(shí)現(xiàn)了功能,但是不知道原因,可以的話希望有人能解答。
廢話少說(shuō),直接賦上代碼。
<template>
<div class="table">
<el-table ref="table">
...
</el-table>
<wp-pager @page-change="pageChange" :total="total" v-if="pager" v-bind="$attrs" v-on="$listeners"></wp-pager>
</div>
</template>
<script>
import { WpPager } from '../pager'
export default {
data() {
return {
scrollTop: null
}
},
activated() {
this.saveScroll()
},
mounted() {
// 監(jiān)聽滾動(dòng)條的位置
this.$refs.table.bodyWrapper.addEventListener('scroll', (res) => {
let height = res.target
this.scrollTop = height.scrollTop
},false)
},
beforeDestroy() {
this.$refs.table.bodyWrapper.removeEventListener('scroll', (res) => {
let height = res.target
this.scrollTop = height.scrollTop
},false)
},
methods: {
// 當(dāng)頁(yè)碼改變的時(shí)候滾動(dòng)條重新到頂部
pageChange (page) {
this.$emit('page-change', page)
this.scrollTop = 0
this.saveScroll()
},
// 這里如果直接賦值給this.$el.querySelector('.el-table__body-wrapper').scrollTop會(huì)失效,需要加上setTimeout才行。
saveScroll() {
this.$nextTick(()=> {
setTimeout(() => {
var scrollTop = this.$el.querySelector('.el-table__body-wrapper')
scrollTop.scrollTop = this.scrollTop
}, 13)
})
}
}
}
</script>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
el-menu實(shí)現(xiàn)橫向溢出截取的示例代碼
在進(jìn)行vue開發(fā)的時(shí)候,我們不可避免會(huì)使用到導(dǎo)航菜單,element方便的為我們提供了導(dǎo)航菜單組件,下面這篇文章主要給大家介紹了關(guān)于el-menu實(shí)現(xiàn)橫向溢出截取的相關(guān)資料,需要的朋友可以參考下2022-06-06
Vue?3.0?v-for中的Ref數(shù)組用法小結(jié)
在?Vue?2?中,在?v-for?里使用的?ref?attribute會(huì)用ref?數(shù)組填充相應(yīng)的?$refs?property,本文給大家介紹Vue?3.0?v-for中的Ref數(shù)組的相關(guān)知識(shí),感興趣的朋友一起看看吧2023-12-12
Vue3中實(shí)現(xiàn)發(fā)送網(wǎng)絡(luò)請(qǐng)求功能(最新推薦)
Axios是一個(gè)基于Promise的HTTP客戶端,可以在瀏覽器和Node.js中用于發(fā)送HTTP請(qǐng)求,本文主要介紹在Vue3中實(shí)現(xiàn)發(fā)送網(wǎng)絡(luò)請(qǐng)求功能,感興趣的朋友一起看看吧2023-12-12
解決vue組件中使用v-for出現(xiàn)告警問(wèn)題及v for指令介紹
這篇文章主要介紹了解決vue組件中使用v-for出現(xiàn)告警問(wèn)題,在文中給大家介紹了v for指令,需要的朋友可以參考下2017-11-11
在?Vue?中使用?dhtmlxGantt?組件時(shí)遇到的問(wèn)題匯總(推薦)
dhtmlxGantt一個(gè)功能豐富的甘特圖插件,支持任務(wù)編輯,資源分配和多種視圖模式,這篇文章主要介紹了在?Vue?中使用?dhtmlxGantt?組件時(shí)遇到的問(wèn)題匯總,需要的朋友可以參考下2023-03-03
通過(guò)vue-cli來(lái)學(xué)習(xí)修改Webpack多環(huán)境配置和發(fā)布問(wèn)題
這篇文章主要介紹了隨著Vue-cli來(lái)'學(xué)'并'改'Webpack之多環(huán)境配置和發(fā)布的相關(guān)知識(shí),本文將會(huì)根據(jù)一些實(shí)際的業(yè)務(wù)需求,先學(xué)習(xí)vue-cli生成的模版,然后在進(jìn)行相關(guān)修改,感興趣的朋友一起跟著小編學(xué)習(xí)吧2017-12-12
Vue中nprogress頁(yè)面加載進(jìn)度條的方法實(shí)現(xiàn)
這篇文章主要介紹了Vue中nprogress頁(yè)面加載進(jìn)度條的方法實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
vue2.0 兄弟組件(平級(jí))通訊的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue2.0 兄弟組件(平級(jí))通訊的實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-01-01

