vue material md-table scroll event bin

40 阅读1分钟

有这么一个需求,使用 vue-material 的 md-table 组件的 Fixed headers 样式效果显示数据

默认表格显示100条数据,如果滚动条滑动到最底部时,再加载100条数据,不停更新表格数据,直到把所有数据显示完为止

实现需求需要监听 md-table 中的滚动条,判断滚动到底触发对应操作

一般都是直接监听整个页面的滚动条,md-table 的滚动条监听需要做个小改动,监听事件才有效

####example.vue

md-table 设置 ref 属性,在 mounted() 中需要用到

<md-table v-model="tableData" md-card md-fixed-header ref="cardTable">
  <md-table-toolbar>
    <h1 class="md-title">title</h1>
  </md-table-toolbar>
  <md-table-row slot="md-table-row" slot-scope="{ item }">
    <md-table-cell v-for="(v, k) in item" :md-label="k" :key="k">
      {{v}}
    </md-table-cell>
  </md-table-row>
</md-table>
mounted () {
...

let cardTable = this.$refs.cardTable
// 获取页面中的滚动条所在的元素
let lastEle = cardTable.$el.lastElementChild 
// 滚动监听
lastEle.addEventListener('scroll', () => {
  // 判断滚动条是否到底
  if (lastEle.scrollHeight - lastEle.scrollTop === lastEle.clientHeight) {
    // do something 
    console.log('我是有底线的.')
  }
}, false)

...  
}

只要找到 md-table 生成的滚动条所在的元素位置,给元素添加对应的滚动监听事件就OK了

scroll

developer.mozilla.org/en-US/docs/…

scrollHeight

developer.mozilla.org/en-US/docs/…

scrollTop

developer.mozilla.org/en-US/docs/…

clientHeight

developer.mozilla.org/en-US/docs/…