国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Vue實現一個無限加載列表功能

2019-11-19 12:31:59
字體:
來源:轉載
供稿:網友

一個需要判斷的地方就是加載中再次觸發滾動的時候,不要獲取數據。

<!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實現一個無限加載列表功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 甘孜| 曲水县| 防城港市| 靖西县| 长寿区| 新宾| 乐都县| 清涧县| 黎平县| 东安县| 双鸭山市| 桂林市| 卢龙县| 阳曲县| 铅山县| 修文县| 日喀则市| 清丰县| 伊通| 恩施市| 夏津县| 维西| 云梦县| 威海市| 澜沧| 闵行区| 大荔县| 南平市| 筠连县| 彩票| 涞源县| 黄浦区| 乌审旗| 龙口市| 漳平市| 哈巴河县| 凤庆县| 枣庄市| 阆中市| 乌兰浩特市| 乐山市|