vue2.0无限滚动加载数据插件

 

做vue项目用到下拉滚动加载数据功能,由于选的UI库(element)没有这个组件,就用Vue-infinite-loading 这个插件代替,使用中遇到的一些问题及使用方法,总结作记录!

安装:npm install vue-infinite-loading –save

引入

ES6

import InfiniteLoading from ‘vue-infinite-loading‘;

export default {
  components: {
    InfiniteLoading,
  },
};

CommonJS

const InfiniteLoading = require(‘vue-infinite-loading‘);

export default {
  components: {
    InfiniteLoading,
  },
};

1.用法一(基本用法)

Template

<div>
  <p v-for="item in list">
    Line:
    <span v-text="item"></span>
  </p>
  <!--infinite-loading这个组件要放在列表的底部,滚动的盒子里面!-->
  <infinite-loading @infinite="infiniteHandler"></infinite-loading>
</div>

Script

import InfiniteLoading from ‘vue-infinite-loading‘;

export default {
  data() {
    return {
      list: [],
    };
  },
  methods: {
    infiniteHandler($state) {
      setTimeout(() => {
        const temp = [];
        for (let i = this.list.length + 1; i <= this.list.length + 20; i++) {
          temp.push(i);
        }
        this.list = this.list.concat(temp);
        $state.loaded();
      }, 1000);
    },
  },
  components: {
    InfiniteLoading,
  },
};

2.用法二(一般的分页数据)

Template

<div class="hacker-news-list">
  <ul>
      <li class="hacker-news-item" v-for="(item, key) in list"></li>
  </ul>
  <infinite-loading @infinite="infiniteHandler">
    <span slot="no-more">
      There is no more Hacker News
    </span>
  </infinite-loading>
</div>

Script

import InfiniteLoading from ‘vue-infinite-loading‘;
import axios from ‘axios‘;

export default {
  data() {
    return {
      list: [],
    };
  },
  methods: {
    infiniteHandler($state) {
     const api="http://xxxx.com/xxx"
      axios.get(api, {   //api为你请求数据地址
        params: {
          page: this.list.length / 10 + 1,   //页码参数(10条每页)
        },
      }).then((response) => {
        if (response.data.length) {
          this.list = this.list.concat(response.data);  //response.data为你请求接口返回的数组列表
          $state.loaded();
          if (this.list.length / 10 === 10) {
            $state.complete(); //这里是加载了10页数据,设置不在加载
          }
        } else {
          $state.complete();
        }
      });
    },
  },
  components: {
    InfiniteLoading,
  },
};

$state: 该组件会传递一个特殊的事件参数$state给事件处理器来改变加载状态,
$state参数包括三个方法,它们是loaded方法,complete方法和reset方法。

  • loaded方法用于在每次加载数据后停止播放动画,然后该组件将准备好进行下一次触发。
  • complete方法用于完成完整的无限加载,则该组件将不再处理任何滚动操作。如果在loaded调用complete方法时永远不会调用该方法,则此组件将显示用户的否结果消息,如果不是,则将显示不再有用户消息,并且可以按slot设其它内容
  • reset方法是将组件返回到原来的状态

3.用法三

一般的无限滚动下拉加载数据会带有筛选条件。比如根据不同条件选择出来的列表,或者改变某个状态重新渲染列表就要用这个用法了

Template

<div class="hacker-news-list">
  <div class="hacker-news-header">
     <!--下拉改变-->
    <select v-model="tag" @change="changeFilter()">
      <option value="story">Story</option>
    </select>
      <!--或者点击改变-->
    <button @click="changeFilter()">搜索</button>
  </div>

  <ul>
      <li class="hacker-news-item" v-for="(item, key) in list"></li>
   </ul>
  <infinite-loading @infinite="infiniteHandler" ref="infiniteLoading">  <!--不要忘记设置这个 ref="infiniteLoading"-->
    <span slot="no-more">
      There is no more Hacker News
    </span>
  </infinite-loading>
</div>

Script

import InfiniteLoading from ‘vue-infinite-loading‘;
import axios from ‘axios‘;

export default {
  data() {
    return {
      list: [],
      tag: ‘story‘,
    };
  },
  methods: {
    infiniteHandler($state) {
      const api="http://xxxx.com/xxx"
      axios.get(api, {   //api为你请求数据地址
        params: {
          tags: this.tag,  //改变的条件参数
          page: this.list.length / 10 + 1,
        },
      }).then(({ data }) => {
        if (data.hits.length) {
          this.list = this.list.concat(data.hits);
          $state.loaded();
          if (this.list.length / 20 === 10) {
            $state.complete();
          }
        } else {
          $state.complete();
        }
      });
    },

    //改变条件条用此方法
    changeFilter() {
      this.list = [];
      this.$nextTick(() => {
        this.$refs.infiniteLoading.$emit(‘$InfiniteLoading:reset‘);
      });
    },
  },
  components: {
    InfiniteLoading,
  },
};

4.其他用法(特殊条件手动触发)

在大多数情况下,我们希望立即为空列表加载数据,这也是该组件的默认行为。如果你只想控制第一次加载,你可以简单地使用v-if和v-else指令来实现它,但是如果,在一些复杂的情况下,我们需要手动每三页加载一次数据,我们可以使用该方法,

这里我不做详细介绍。有这个需求的可以去看看官方文档:vue-infinite-loading

原文地址:https://www.cnblogs.com/tuspring/p/9803424.html

时间: 2024-08-01 22:43:14

vue2.0无限滚动加载数据插件的相关文章

js滚动加载小插件

本文实例讲述了jquery滚动加载数据的方法.分享给大家供大家参考.具体分析如下: 少废话直接上代码!!!粗暴,直接,干脆 0//lk-2017-05-04 1(function($, win) { 2 var defaults = { 3 'container': '#container', //容器 4 'sections': '.section', //子容器 5 'searchname': '全部', //搜索名称 6 'url': '', //加载更多数据请求的路径 7 'updata

基于 Vue.js 的移动端组件库mint-ui实现无限滚动加载更多

通过多次爬坑,发现了这些监听滚动来加载更多的组件的共同点, 因为这些加载更多的方法是绑定在需要加载更多的内容的元素上的, 所以是进入页面则直接触发一次,当监听到滚动事件之后,继续加载更多, 所以对于无限滚动加载不需要写首次载入列表的函数, 代码如下: html: //父组件 <div v-infinite-scroll="loadMore" infinite-scroll-disabled="loading" infinite-scroll-distance=

前端页面实现滚动加载数据的案例

1.我们在项目中经常会有这样的需求就是需要滚动加载数据: 2.原理利用分页的原理即可实现:见下面代码 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> &l

HTML5商城开发一 楼层滚动加载数据

对于楼层加载在以前只是个想法,从来没实现过,刚好项目中碰到,再此总结一下 场景:HTML5,局部商品列表信息滚动(局部滚动条) 1.通过jq设置subCategoryScroll的高度为屏幕显示高度(假设为100),设置productlist的高度为列表信息的实际高度(假设为300) <div id="subCategoryScroll" style="overflow: hidden; overflow-y: scroll;"> <ul clas

JQ-滚动条下拉无限的加载数据

一.原理 利用滚动的高度,如果滚动的高度到达一定范围,就加载数据 二.实现 利用$(document.body).outerWidth()获取的是屏幕的高度,这个是固定的,不变的 利用$(window).scrollTop()获取您滚动的高度 利用$(document).height()获取总的高度 注:$(widnow).height()这个是可视区的高度,这个跟$(document).height()很容易混淆 三.上代码 <section> <div id="tishi&

使用jquery.more.js来实现滚动加载数据

html <body> <div id="more"> <div class="single_item"> <div class="date"></div> <div class="author"></div> <div class="title"></div> </div> <a

滚动加载数据

function scrollLoad() { var ele = document.getElementById('mainListBlock'); var isLastPage = false; window.isLoading = false; var clientHeight = getClientHeight(); function getScrollTop() { return ele.scrollTop; } function getScrollHeight() { return

vue2.0实现图片加载失败默认显示图片

<div class="bg"> <img :src="goods.phoneFloorAd.resUrl" :onerror="errorImg01"> </div> <script type="text/ecmascript-6"> export default { data () { return { errorImg01: 'this.src="' + requ

Android第二十三期 - 256k的ListView下拉刷新和滚动加载数据

代码已经