vue 上拉刷新组件
背景,项目中经常会出现需要上拉加载更多或者下拉刷新的需求,一直以来呢都是借用各种UI库来实现,但是不知道啥情况,最近在使用的时候,一直有问题,出不了效果,然人很恼火,于是只能自己动手来实现以下,
这次做得呢也很简单,只做了上拉加载更多,思路其实很简单,搞一个组件,然后弄个插槽暴露出去放列表,然后在这个组件上监听touchstart,move,end等事件
我们一般只需要已经滑到最底部了,在上滑才需要判断是否加载更多
所以我们需要弄清楚几个条件
1,是否滑动到最底部了,如果是的话,那么在监听到上滑,就计算滑动的距离,如果距离达到了阈值,那么就加载更多
在处理加载的过程中,一般会给一些文字提示,比如,login中,已经没有更多了,...
2,如果没有滑动到最底部,那么就是普通的页面滑动,我们不做处理
大体上就是这些,大部分其他的库会有一些动画效果,我这里没加,具体代码如下:
<template>
<div class="pull-wrap" @touchstart="start" @touchmove="move" @touchend="end">
<!--上拉加载组件-->
<slot ref="pull" class="pull-content"></slot>
<p v-if="isMoving" style="font-size: 20px;">pulling....</p>
<div class="is-loading" v-if="isLoading">
<img class="loading" src="../assets/images/loading.svg" alt="">
</div>
<div class="is-done" v-if="isDone">没有数据了</div>
</div>
</template> <script>
export default {
name: 'Pull',
props: {
onPull: { // 上拉的回调
type: Function,
require: true
} },
data() {
return {
startY: 0,
moveY: 0,
isMoving: false,
isLoading: false,
isDone: false,
num: 1 // history list的页数
}
},
methods: {
start(e) {
this.startY = e.touches[0].clientY;
console.log(this.startY);
},
move(e) {
if (this.isDone) return
console.log('move', e.touches[0].clientY);
// 滑动时需要检测是否到底了,如果还没到底,就不要loading
// if (this.isLoading || this.isDone) return;
let flag = this.scrollToTheEnd();
if (flag) {
this.isMoving = true
}
this.moveY = e.touches[0].clientY - this.startY;
}, end() {
// this.isMoving = false
if (this.isLoading || this.isDone) return;
console.log('touchend', this.moveY);
if (this.moveY > -40) {
console.log('没超过', this.moveY);
this.isMoving = false;
} else {
console.log('达到条件了');
let flag = this.scrollToTheEnd();
console.log(flag, '到底了吗');
if (!flag) return;
this.isMoving = false
this.num++;
this.isLoading = true;
this.onPull(this.num);
}
this.startY = 0;
this.moveY = 0;
}, /**
* 判断滚动条是否到底
*/
scrollToTheEnd() {
let scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop // 滚动的距离
let viewHeight = document.documentElement.clientHeight; // 可视区域高度
let offsetHeight = document.body.scrollHeight; // 总高度
console.log(scrollTop, viewHeight, offsetHeight, '----------------');
// 滚动条到底部的条件
return (viewHeight + scrollTop) >= offsetHeight
}
}, mounted() {
this.$on('loadEnd', () => {
console.log('load完毕了');
this.isLoading = false
}) this.$on('loadOver', () => {
console.log('没有了');
this.isDone = true;
this.isLoading = false;
this.isMoving = false;
}) }
}
</script> <style scoped lang="scss">
/*.pull-wrap{
overflow: hidden;
&>.pull-content{
transition: all .4s;
}
}*/
.pull-wrap{
font-size: 20px;
} .loading{
width: 50px;
height: 50px;
} </style>
然后使用组件的如下:
<template>
<Pull :onPull="pull" ref="pull">
<p v-for="val in list">列表了{{val}}</p>p
</Pull>
</template> <script>
import Pull from '../Pull'
methods:{ //这里就是加载更多的处理函数了,这里只是用定时器模拟了一下,需要将加载状态回传到子组件中去
pull(num) {
console.log('pull回调');
setTimeout(() => {
this.num = num;
if (this.history_list.length >= this.pk_list_data.others_family_list.length) {
console.log('完了');
this.$refs.pull.$emit('loadOver') // 加载完毕
} else {
this.$refs.pull.$emit('loadEnd') // 加载完毕
} }, 2000) }, } </script>
这样,基本就做完了,
vue 上拉刷新组件的更多相关文章
- Vue下拉刷新组件
Examples examples Installation npm install vue-pull-to --save Use Setup <template> <div> ...
- 分享一个discuz touch端的jQuery下拉刷新组件
在线Demo 最近装了个discuz论坛, 趣股VIP吧,发现里面内置的jQuery上拉刷新组件写得还行,STATICURL可以用'http://o9gzet7tk.bkt.clouddn.com/i ...
- vue loadMore 上拉刷新不能实现的坑
1.如果你写的代码没问题,但依然不能实现上拉刷新效果,那你有可能是缺少了overflow: scroll 2.如果上拉刷新一直在加载状态,需要调用this.$refs.loadmore.onBotto ...
- 【UI组件】——用jQuery做一个上拉刷新
技术要点: 1.jQuery的插件写法 2.上拉刷新步骤分解 3.css样式 jQuery的插件写法: $.fn.pluginName = function() { return this.each( ...
- 使用vux实现上拉刷新的总结
最近公司在研发app,选择了基于Vue框架的vux组件库,现总结在实现上拉刷新功能遇到的坑: 1.问题:只刷新一次,解决方法:需要自己手动重置状态 this.scrollerStatus.pullup ...
- Google自己的下拉刷新组件SwipeRefreshLayout
SwipeRefreshLayout SwipeRefreshLayout字面意思就是下拉刷新的布局,继承自ViewGroup,在support v4兼容包下,但必须把你的support librar ...
- MUI - 上拉刷新/下拉加载
新闻信息列表必备的功能,支持Table,Ul等列表. 以下是DIV版本,在安卓端或者ios端必须使用双webview模式,传送门:http://dev.dcloud.net.cn/mui/pulldo ...
- vux (scroller)上拉刷新、下拉加载更多
1)比较关键的地方是要在 scroller 组件上里加一个 ref 属性 <scroller :lockX=true height="-170" :pulldown-conf ...
- Google官方下拉刷新组件---SwipeRefreshLayout
今天在Google+上看到了SwipeRefreshLayout这个名词,遂搜索了下,发现竟然是刚刚google更新sdk新增加的一个widget,于是赶紧抢先体验学习下. SwipeRefreshL ...
随机推荐
- 【ElasticSearch学习】之一图读懂文档索引全过程
ES索引过程详解: 1.客户端发送索引请求. 客户端向ES节点发送索引请求,以RestClient客户端发起请求为例: ES提供了Java High Level REST Client,用户可以通过R ...
- 51NOD 2072 装箱问题 背包问题 01 背包 DP 动态规划
有一个箱子容量为 V(正整数,0<=V<=20000),同时有 n 个物品(0<n<=30),每个物品有一个体积(正整数). 现在在 n 个物品中,任取若干个装入箱内,使得箱子 ...
- 设置 Linux 支持中文
1.首先在 command 输入 locale,可以看到 Linux 下默认的系统语言的是英文 2.vim ~/.bashrc 打开这个文件,该文件夹相当于系统配置文件 3.打开后,将后三行命令输入到 ...
- Python解决钻石小偷问题
题目如下: A:我没有偷钻石. B:D就是罪犯. C:B是盗窃这块钻石的罪犯. D:B有意诬陷我. 假定只有一个人说的是真话,编程序判断谁偷走了钻石. 答案是:说真话的是D,罪犯是A,逻辑思路可以百度 ...
- docker 生产环境基础应用
项目背景 此项目是在已有项目基础上,开发的一套相对独立的系统.项目总体分为三部分,前端.中间应用服务.流媒体服务.前端技术选型为vue+elementui,中间应用服务为.net core webap ...
- C# 基础知识系列- 17 实战篇 编写一个小工具(1)
0. 前言 这是对C# 基础系列的一个总结,现在我们利用之前学到的知识做一个小小的工具来给我们使用. 如果有看过IO篇的小伙伴,应该有印象.当时我提过一个场景描述,我们在平时使用系统的时候,经常会为了 ...
- search(10)- elastic4s-multi_match:多字段全文搜索
在全文搜索中我们常常会在多个字段中匹配同一个查询条件或者在不同的字段中匹配不同的条件.比如下面这个例子: GET /books/_search { "query": { " ...
- 【Spark】Spark-shell案例——单词计数统计
目录 步骤 一.准备本地文件以作测试 二.通过 --master启动本地模式 三.开发scala单词统计代码 步骤 一.准备本地文件以作测试 在第一台机器执行 mkdir -p /export/ser ...
- Spring中bean的四种注入方式
一.前言 最近在复习Spring的相关内容,这篇博客就来记录一下Spring为bean的属性注入值的四种方式.这篇博客主要讲解在xml文件中,如何为bean的属性注入值,最后也会简单提一下使用注解 ...
- Android showStatusIcon on inactive InputConnection异常
在开发的时候突然发现在输入文本框中点击输入法的删除按钮,发现app莫名其妙退出 了.log信息如下: 01-31 16:57:59.524: W/IInputConnectionWrapper(125 ...