mint-ui Infinite scroll 重复加载、加载无效的原因及解决方案
1.无限滚动的运用场景:
一般运用在列表展示,有分页、下拉加载更多的需求中。
2.代码分析
代码很简单,实现了列表分页,数据加载完之后显示数据状态
<template>
<div class="list-data"
v-infinite-scroll="loadMore"
infinite-scroll-disabled="loading"
infinite-scroll-distance="10">
<equipment-list :list="list"></equipment-list>
<div class="loading" v-if="loading">
<span id="load-text">{{loadText}}</span>
</div>
</div>
</template>
<script>
import { findPage } from '@/api/api'
import EquipmentList from 'common/list/EquipmentList.vue'
export default {
data(){
return {
loading:false,
loadText:'正在加载...',
list: [],
param: {
pageIndex: 0,
pageSize: 10
}
},
components:{
EquipmentList
},
methods: {
getList(callBack){
findPage(this.param).then(response => {
if(response.ret){
let data = response.datas
if(!data){data = []} // 上次list的长度
let len = this.list.length // 拼接数据
this.list = this.list.concat(data) if (data && data.length == 0 && !len) {
this.loadText = '没有找到相关数据'
} else if (data && data.length < 10) {
this.loadText = '暂无更多数据'
} else {
this.loading = false
} callBack && callBack()
}
},reject => {})
},
loadMore() {
this.loading = true
this.param.pageIndex += 1
this.getList()
}
}
}
</script>
<style>
.list-data{
height: 100%;
overflow-y: auto;
}
</style>
参考mint-ui官网介绍
1.为HTML元素添加v-infinite-scroll指令即可使用无限滚动。
2.滚动该元素,当其底部与被滚动元素底部的距离小于给定的阈值(通过infinite-scroll-distance设置)时,绑定到 v-infinite-scroll 指令的方法就会被触发。
3.infinite-scroll-disabled若为真,则无限滚动不会被触发,默认为false。
4.infinite-scroll-immediate-check若为真,则指令被绑定到元素上后会立即检查是否需要执行加载方法。在初始状态下内容有可能撑不满容器时十分有用。默认为true。
但是,3和4实际效果却和官网描述有出入,实际效果:实际效果:实际效果:
1.为HTML元素添加 v-infinite-scroll 指令即可使用无限滚动。
2.滚动该元素,当其底部与被滚动元素底部的距离小于给定的阈值(通过infinite-scroll-distance设置)时,绑定到 v-infinite-scroll 指令的方法就会被触发。
3.infinite-scroll-disabled 若为真,如果上次加载的数据没有撑满容器,则立即再次执行绑定到 v-infinite-scroll 指令的方法(loadMore),直到数据撑满容器为止。在初始状态下内容有可能撑不满容器时十分有用,默认为false。
4.infinite-scroll-immediate-check,若为真 则指令被绑定到元素上后会立即执行加载方法(loadMore),默认为true。
填坑
1.重复加载。初次进入列表页,会加载两次或者多次数据
造成重复加载的原因,罪魁祸首是infinite-scroll-disabled,在 loadMore 方法里 有一句 this.loading = true,把infinite-scroll-disabled的值设置为了true,
它的作用就是,当你进入页面是,会检查如果第一次请求的数据没有撑满你的容器(list-data),就会立即再次执行v-infinite-scroll 绑定的方法(loadMore),第二次没有撑满,会执行第三次。。。。。。
2.滚动时,不起作用
这种情况,就是在loadMore方法里没有写this.loading = true,同时,第一次加载的数据也没有撑满容器。而我们的样式设置:
.list-data{
height: 100%;
overflow-y: auto;
}
根本原因是因为,数据没有撑满容器就不会有滚动效果,所以就不会起作用了。
所以解决方案 就是要出现滚动条 !!! 容器高设置的小一点,或者每页的数据多一点。
注:
1.为什么没有在created 里调用一次getlist方法?为什么pageIndex 默认为0?
因为infinite-scroll-immediate-check默认为 true,进入页面会直接调用loadMore 。
2.容器的样式需要设置height和 允许滚动overflow-y:auto;
mint-ui Infinite scroll 重复加载、加载无效的原因及解决方案的更多相关文章
- Vue2 框架开发的单页程序页面首次加载慢的原因与优化方案
在用Vue2 框架进行单页面开发时,开发完成后项目打包到线上环境,发现vendor脚本有963K,app.css文件也有四百多k,用户第一次打开网页加载这两个文件要十多秒,会使页面白屏十多秒,之后再次 ...
- iOS开发——加载、滑动翻阅大量图片解决方案详解
加载.滑动翻阅大量图片解决方案详解 今天分享一下私人相册中,读取加载.滑动翻阅大量图片解决方案,我想强调的是,编程思想无关乎平台限制. 我要详细说一下,在缩略图界面点击任意小缩略图后,进入高清 ...
- Android高效加载大图、多图解决方案,有效避免程序内存溢出现象
好久没有写博客了,今天就先写一个小的关于在Android中加载大图如何避免内存溢出的问题. 后面会写如何使用缓存技术的核心类,android.support.v4.util.LruCache来加载图片 ...
- C#连接Sqlite 出现:混合模式程序集是针对“v2.0.50727”版的运行时生成的,在没有配置其他信息的情况下,无法在 4.0 运行时中加载该程序集。的解决方案
C#连接Sqlite 出现: 混合模式程序集是针对“v2.0.50727”版的运行时生成的,在没有配置其他信息的情况下,无法在 4.0 运行时中加载该程序集.的解决方案 C#连接sqlite数据库代码 ...
- Android UI之View的加载机制(二)
转载请标明出处:http://blog.csdn.net/sk719887916/article/details/39961201,作者:skay 对于接触安卓开不到一年的自己来说,总结下view的生 ...
- 关于 Mybatis 设置懒加载无效的问题
看了 mybatis 的教程,讲到关于mybatis 的懒加载的设置: 只需要在 mybatis 的配置文件中设置两个属性就可以了: <settings> <!-- 打开延迟加载的开 ...
- 9.【nuxt起步】-scroll分页加载
面是单页,下面实现一个列表页和分页加载的例子 1.新建pages/list.vue <template> <div> 分页加载列表页面 </div> </te ...
- iOS开发UI篇-懒加载、重写setter方法赋值
一.懒加载 1.懒加载定义 懒加载——也称为延迟加载,即在需要的时候才加载(效率低,占用内存小).所谓懒加载,写的是其get方法. 注意:如果是懒加载的话则一定要注意先判断是否已经有了,如果没有那么再 ...
- HTML prefetch 预加载无效的记录
在link中新增: <link rel="prefetch" href="/view/search.html" /> 预加载会将内容缓存到浏览器, ...
随机推荐
- java学习笔记(二):枚举值
枚举值的作用:枚举限制了变量要有一些预先定义的值,运用枚举值可以大大减少你的代码中的漏洞,举例来说,如果我们想为一家鲜榨果汁店编个程序,就可以将杯子的尺寸限制为小中和大.这样就可以确保人们不会定大中小 ...
- LENGTH()和CHAR_LENGTH()区别
LENGTH()返回以字节为单位的字符串的长度.CHAR_LENGTH()返回以字符为单位的字符串的长度. 分别对应于java中的str.getBytes().length和str.length( ...
- 652. Find Duplicate Subtrees找出重复的子树
[抄题]: 就是出现了多次的子树,可以只包括一个点. Given a binary tree, return all duplicate subtrees. For each kind of dupl ...
- HTTP状态码之【整理篇】
=================================================================================== 状态码的职责:当客户端向服务器端 ...
- docker 支持ipv6 (核心要点是ndp需要把docker内的ip全部加入到ndplist中来)
IPv6 with Docker Estimated reading time: 10 minutes The information in this section explains IPv6 wi ...
- Call to undefined function Workerman\posix_getpid()
安装扩展 yum install php-posix
- zeromq学习记录(八)负载均衡 附ZMQ_ROUTER的流程分析
/************************************************************** 技术博客 http://www.cnblogs.com/itdef/ ...
- redis在游戏服务器中的使用初探(四) redis应用
文章系列先介绍环境搭建 介绍redis操作和代码编写运行 这是典型的实战工程过程.那么我们为何要使用redis而不是常规的数据库比如 mysql呢? 因为KV内存数据库最大的优势所有数据全部存储在内 ...
- 渗透测试的理论部分2——OSSTMM的详细描述
昨天休息了一天,今天我要连更两篇博客,作为补充,以下为正文 本章详细描述了OSSTMM内的RAV得分这一理论概念,对日后从事正规安全工作至关重要 OSSTMM为开源安全测试方法论,对OSSTMM不了解 ...
- 2019.02.15 codechef Favourite Numbers(二分+数位dp+ac自动机)
传送门 题意: 给444个整数L,R,K,nL,R,K,nL,R,K,n,和nnn个数字串,L,R,K,数字串大小≤1e18,n≤65L,R,K,数字串大小\le1e18,n\le65L,R,K,数字 ...