Element UI中v-infinite-scroll无限滚动组件使用详解

目录
  • 一、v-infinite-scroll无限滚动组件使用详解
  • 二、组件无限加载原因及解决方式
  • 三、总结
  • 总结

一、v-infinite-scroll无限滚动组件使用详解

 1、v-infinite-scroll="load" //load无限滚动加载的方法
 2、infinite-scroll-disabled //是否禁用无限滚动加载
 3、infinite-scroll-delay //节流时延,单位为ms
 4、infinite-scroll-distance //触发加载的距离阈值,单位为px
 5、infinite-scroll-immediate //是否立即执行加载方法,以防初始状态下内容无法撑满容器。
 //默认情况下,infinite-scroll-disabled是false,因此如果组件使用无限滚动加载组件,即使在vue不进行加载方法的调用,组件也会调用该方法,因此如果需要控制的话,尽量是使用infinite-scroll-disabled属性来进行加载方法是否调用的控制。

二、组件无限加载原因及解决方式

1、问题:使用无限加载的div没有设置高度导致无限加载

解决方案:
<div v-infinite-scroll="load" :infinite-scroll-disabled="isInfiniteScrollDisabled" style="margin-bottom: 20px;height:640px;overflow-y:auto" //style的设置非常关键,一定要设置height高度 >

在指令使用的div一定要限定高度(height:xxx; overflow-y:auto)load加载方法将在拉取底部时才会被执行。

2、问题:为什么在vue中并没有在任何生命周期中进行load方法的调用,直接就加载了方法?

解决方案:使用 :infinite-scroll-disabled="isInfiniteScrollDisabled“属性来进行控制。

3、代码demo演示

<template>
  <div class="vue-class-name">
    <div
      v-infinite-scroll="load"
      :infinite-scroll-disabled="isInfiniteScrollDisabled"
      style="margin-bottom: 20px;height:640px;overflow-y:auto"
    >
      <div
        v-for="item in dataList"
        :key="item.index"
        style="display: inline-block;margin:0px 10px 10px 0px"
      >
        <span>{{item}}</span>
      </div>
      <el-empty
        description="No Data"
        v-if="dataList.length == 0"
        style="height:650px;overflow-y:auto;text-align:center"
      ></el-empty>

      <!-- 这个div一定要放在使用指令的div里面-->
      <div align="center" v-if="dataList.length > 0">
        <div class="drawer-footer">
          <span v-if="pullStatus === $enum.STATUS.START">
            Pull up to load more
          </span>
          <span v-if="pullStatus === $enum.STATUS.LOADING">
            loading
            <i class="el-icon-loading"></i>
          </span>
          <span v-if="pullStatus === $enum.STATUS.NODATA">
            no more data
          </span>
        </div>
      </div>
    </div>
  </div>
</template>
<script>
export default {
  name: 'VueName',
  mixins: [],
  components: {},
  props: {},
  data: function() {
    return {
     pullStatus: this.$enum.STATUS.START,
     pageIndex: 1,
     pageSize: 20,
     dataList: [],
     isInfiniteScrollDisabled: false,
    };
  },
  computed: {},
  watch: {
  //事件监听:当刷新浏览器页面或者切换项目的时候进行方法调用
    projectSpaceId: function(value, oldValue) {
      this.dataList = [];
      this.pageIndex = 1;
      this.pullStatus = this.$enum.STATUS.START;
      this.getLoadMoreData();
    },
  },
  created() {},
  mounted() {
  //一进入页面进行方法调用
    this.getLoadMoreData();
  },
  methods: {
    getLoadMoreData() {
      if (this.pullStatus !=  this.$enum.STATUS.START) {
       return;
       }
      this.pullStatus = this.$enum.STATUS.LOADING;
      this.isInfiniteScrollDisabled = true;
      let params = {};//请求参数,可省略
      this.getData(params).then(resp => {
        if (data.length < this.pageSize ) {
                this.pullStatus = this.$enum.STATUS.NODATA;
            } else {
                this.pageIndex++;
                this.pullStatus = this.$enum.STATUS.START;
            }
        if (resp.data.length > 0) {
          this.dataList = this.dataList.concat(resp.data);//数组拼接,得到拼接后的数据
        }
        this.isInfiniteScrollDisabled = false;
      });
    },
  },
  beforeDestroy() {
    this.dataList = []; //清空数组
};
</script>
<style scoped></style>
//常量定义
export const STATUS= {
  START: 0, // 上拉加载
  LOADING: 1, // 加载中
  NODATA: 2, // 没有更多数据
};

三、总结

当然,这个组件还有很多可以优化的地方,比如:可以将下面这一段代码抽成公共组件,使用该组件的地方,只需要传当前的pullStatus状态即可。

<div class="drawer-footer">
          <span v-if="pullStatus === $enum.STATUS.START">
            Pull up to load more
          </span>
          <span v-if="pullStatus === $enum.STATUS.LOADING">
            loading
            <i class="el-icon-loading"></i>
          </span>
          <span v-if="pullStatus === $enum.STATUS.NODATA">
            no more data
          </span>
        </div>

同时,也可以封装成一个mixins,这样同一个项目,如果多处需要滚动分页,那么这样代码就会更加简洁和方便,下面我粘贴一下mixins里面的代码:

/**
 * 页面无限滚动加载
*/
export default  {
    name: "infiniteScrollMixins",
    data() {
        return {
            pullStatus: this.$enum.STATUS.START,
            pageIndex: 1,
            pageSize: 20,
        }
    },
    computed:  {},
    created() {},
    methods: {
        loadMoreData() {
            if (this.pullStatus !=  this.$enum.STATUS.START) {
                return;
            }
            this.pullStatus = this.$enum.STATUS.LOADING;
            if(this.getLoadMoreData) {
            //使用该mixins的组件需要定义该方法
                this.getLoadMoreData();
            }
        },

        setPullStatus(data = []) {
            if (data.length < this.pageSize ) {
                this.pullStatus = this.$enum.STATUS.NODATA;
            } else {
                this.pageIndex++;
                this.pullStatus = this.$enum.STATUS.START;
            }
        }
    },
    beforeDestroy() {},
};

如何使用封装的mixins?

1、导入: import 名称 from ‘路径’;

2、声明: mixins: [mixins名称],

3、此时mixins中定义的data/methods/computed等,在该组件中都可以直接使用,且多个使用mixins的组件的各个变量是相互独立的,值的修改在组件中不会相互影响。(此处不理解可以去学习一下mixins的相关文档)

总结

到此这篇关于Element UI中v-infinite-scroll无限滚动组件使用的文章就介绍到这了,更多相关Element UI v-infinite-scroll无限滚动组件内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解无限滚动插件vue-infinite-scroll源码解析

    最近在项目中遇到一个需求,有一个列表需要滚动加载,类似于微博的无限滚动.当时第一反应时监听滚动事件,在判断滚动到达底部时加载下一页,同时心里也清楚,监听滚动事件需要做好截流.顺手搜索了下发现有一个现成的插件vue-infinite-scroll,用法也很简单,于是乎就用了起来. 需求上线后,对它的实现挺好奇的,于是研究了一番源码,这篇文章就是源码解析笔记. 插件使用方法 这是一个 vue 的指令,按照 github 仓库上的介绍,用法挺简单的,例如: <div class="app&quo

  • 使用vue-infinite-scroll实现无限滚动效果

    vue-infinite-scroll插件可以无限滚动实现加载更多,其作用是是当滚动条滚动到距离底部的指定高度时触发某个方法. https://github.com/ElemeFE/vue-infinite-scroll/ https://www.npmjs.com/package/vue-infinite-scroll npm i vue-infinite-scroll --save main.js使用 import vueiInfinite from 'vue-infinite-scroll

  • Element UI中v-infinite-scroll无限滚动组件使用详解

    目录 一.v-infinite-scroll无限滚动组件使用详解 二.组件无限加载原因及解决方式 三.总结 总结 一.v-infinite-scroll无限滚动组件使用详解 1.v-infinite-scroll="load" //load无限滚动加载的方法 2.infinite-scroll-disabled //是否禁用无限滚动加载 3.infinite-scroll-delay //节流时延,单位为ms 4.infinite-scroll-distance //触发加载的距离阈值

  • element UI中在 el-select 与 el-tree 结合组件实现过程

    前言 项目上实现某个功能,使用到了 el-select 和 el-tree 组合实现,记录下两者结合的实现过程. 要求根据项目接口提供的数据,el-tree 里的数据是一次性返回来的,点击最后一层级时,请求接口,在点击层级下方追加数据追加的数据要显示勾选框,可进行勾选,且是单选勾选后需要返回勾选的层级以及它的父级 实现效果如下: 数据回显效果: 实现关键部分 el-tree里的显示勾选框不符合当前“追加的数据要显示勾选框,可进行勾选”这个需求,所以我修改了el-tree的源码进行使用. 追加子级

  • 使用Element的InfiniteScroll 无限滚动组件报错的解决

    一.问题描述 在使用Element的InfiniteScroll 无限滚动时候出现以下错误: TypeError: Failed to execute 'observe' on 'MutationObserver': parameter 1 is not of type 'Node' InfiniteScroll的更多用法element官网 二.解决办法 给需要使用 InfiniteScroll 的元素或者它的父级元素加上 overflow:auto; 属性即可. <template> <

  • vue2.0 + element UI 中 el-table 数据导出Excel的方法

    1.安装相关依赖 主要是两个依赖 npm install --save xlsx file-saver 如果想详细看着两个插件使用,请移步github. https://github.com/SheetJS/js-xlsx https://github.com/eligrey/FileSaver.js 2.组件里头引入 import FileSaver from 'file-saver' import XLSX from 'xlsx' 3.组件methods里写一个方法 exportExcel

  • Web Components实现类Element UI中的Card卡片

    目录 引言 Web Components 核心组成 1. Custom Elements 2. Shadow DOM 3. templates 和 slots 完整代码 Web Components vs Vue Components Web Components 生命周期回调函数 优点 and 缺点 七.基于web components的框架 引言 Web Components 是一个浏览器原生支持的组件化方案,允许你创建新的自定义.可封装.可重用的HTML 标记.不用加载任何外部模块,直接就

  • Element UI中table单元格合并的解决过程

    目录 引言 解决思路: 1.格式化后台返回的数据(根据实际数据格式处理) 2.在 data 中定义数据,需要合并几列就定义几个数组和索引 3.定义合并函数 4.table 组件属性 span-method 的单元格合并方法: 完整代码: 总结 引言 项目中遇到表格单元格合并的需求,在此记录整个解决过程. 项目使用的是 Element UI,表格使用的是 table 组件.Element UI 的 table 表格组件中对单元格进行合并,需要使用 table 组件的 span-method 属性.

  • element UI 中的 el-tree 实现 checkbox 单选框及 bus 传递参数功能

    el-tree 单选功能 在日常项目开发中,会经常遇到,树形结构的查询方式,为了快速方便开发,常常会使用到快捷的ui组件去快速搭树形结构,这里我用的是 element ui 中的 el-tree .第一次接触这种功能的时候也是各种网站查询,虽然也都能实现功能,但是都会有一些小问题,就很难受,那么我们废话不多说(好像也说了不少呢),直接上效果. el-tree 单选 html 代码 *** 注: load 和 lazy 属性不是需要的粘贴时请删除.(只有需要懒加载的树才需要,关于怎样构建懒加载树以

  • 关于element ui中el-cascader的使用方式

    目录 element ui中el-cascader使用 例→ 代码 element中el-cascader使用及自定义key名 element ui中el-cascader使用 要想实现进入页面直接选中选择器中的选项 例→ 那v-model绑定的值必须是数组形式的!!(element ui官方文档中没提到这一点好像,我也是试了很多次才发现的) 代码 <el-form-item label="分类:" prop="region" class="regi

  • 简单方法实现Vue 无限滚动组件示例

    目录 1. 前言 2. 整体思路 开始 3. 钩子函数 3.1 获取偏移初始位置的像素值 3.2 获取开始滚动和结束滚动的钩子函数 4. 完整代码 1. 前言 对于列表类型的大量数据,前端展示往往采用 分页 和 无限滚动 的方式来展示,对于用户来说,鼠标滚轮和触控屏使滚动行为要比点击更快更容易. element-plus 组件库提供了简单的 vue 指令,就可以轻易的实现 但是 element-plus 只支持无限向下滚动,不支持无限向上滚动,同时也没缺少丰富的 钩子函数,我们无法在这个基础上更

  • Android 控制ScrollView滚动的实例详解

    Android 控制ScrollView滚动的实例详解 在开发中,我们经常需要更新列表,并将列表拉倒最底部,比如发表微博,聊天界面等等, 这里有两种办法,第一种,使用scrollTo(): public static void scrollToBottom(final View scroll, final View inner) { Handler mHandler = new Handler(); mHandler.post(new Runnable() { public void run()

随机推荐