Vue实现一个无限加载列表功能
程序员文章站
2022-05-28 20:42:23
一个需要判断的地方就是加载中再次触发滚动的时候,不要获取数据。
&l...
一个需要判断的地方就是加载中再次触发滚动的时候,不要获取数据。
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>列表无限加载</title> <style> * { margin: 0; padding: 0; } li { height: 50px; border-bottom: 1px solid #c7c7c7; list-style: none; line-height: 50px; padding-left: 30px; } </style> </head> <body> <div id="unlimitedlist"> <ul> <li v-for="item in list">{{ item }}</li> <li :style="{display: loading ? 'initial' : 'none'}">loading......</div> </ul> </div> <script src="https://cdn.jsdelivr.net/npm/vue@2.5.17/dist/vue.js"></script> <script> function fetch(from, size = 20) { // 模拟后台获取数据 console.log('获取数据 传入: ', { from, size }); let data = []; let total = 98; size = math.min(size, total - from + 1); for (let i = 0; i < size; i++) { data.push(`列表项${from + i}`); } let ret = { data, total }; return new promise(function (resolve, reject) { settimeout(() => { console.log('获取数据 返回: ', ret); resolve(ret); }, 500); }) } new vue({ el: '#unlimitedlist', data: { list: [], loading: true, // 数据加载中 allloaded: false // 数据已经全部加载 }, methods: { getdata() { this.loading = true; // 显示加载中的标识 fetch(this.list.length + 1).then(res => { this.list.splice(this.list.length, 0, ...res.data); // 将新获取到的数据连接到 this.list (vue 能检测到 splice() 函数 this.loading = false; // 加载结束 取消加载中显示 if (this.list.length === res.total) { this.allloaded = true; } }) }, onscroll(e) { if (this.loading || this.allloaded) return; let top = document.documentelement.scrolltop || document.body.scrolltop; // 滚动条在y轴上的滚动距离 let vh = document.compatmode == 'css1compat' ? document.documentelement.clientheight : document.body.clientheight; // 浏览器视口的高度 let height = math.max(document.body.scrollheight, document.documentelement.scrollheight); // 文档的总高度 if (top + vh >= height) { // 滚动到底部 this.getdata(); // 如果已经滚到底了 获取数据 } } }, created() { this.getdata(); window.addeventlistener('scroll', this.onscroll); }, destroyed () { window.removeeventlistener('scroll', this.onscroll); } }) </script> </body> </html>
总结
以上所述是小编给大家介绍的vue实现一个无限加载列表功能,希望对大家有所帮助