欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue实现一个无限加载列表功能

程序员文章站 2023-01-29 14:52:09
一个需要判断的地方就是加载中再次触发滚动的时候,不要获取数据。 &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实现一个无限加载列表功能,希望对大家有所帮助