vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件
vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件/库
一提到移动端的下拉刷新上拉翻页,你可能就会想到iScroll插件,没错iScroll是一个高性能,资源占用少,无依赖,多平台的javascript滚动插件。iScroll不仅仅是 滚动。它可以处理任何需要与用户进行移动交互的元素。在你的项目中包含仅仅4kb大小的iScroll,你的项目便拥有了滚动,缩放,平移,无限滚动,视差滚动,旋转功能。iScroll的强大毋庸置疑,本人也非常欢迎大家使用iScroll。还有dropload也是挺好用的。
本文讲到的上拉翻页加载更多方法的核心思路其实很简单,思路一看就懂,大道至简嘛,虽然代码很少,不过实现过程中的视图与数据的交互逻辑还有有些复杂,不细心的话,很容易蒙圈,往往特别简单的东西,背后都有很细致入微的逻辑关系。
本文的方法,初步是在vue-cli的环境下实现,代码包含了template和script,方法有用到document,window对象,初版有些粗糙。
本文实现上拉翻页加载更多的核心思路就是:如果“正在加载”这个层被上拉超出页面底部,就触发加载下一页的方法,对就是这么简单!
本文方法最繁琐的地方主要在于交互方面:几个“正在加载”的层根据数据渲染的时机和上拉操作时候的显隐控制。方法里面大多数语句后面都有注释讲解,细心点应该能理顺逻辑。本文只写了上拉翻页的功能展示,下来刷新更简单也同样的道理(每次触发都只加载第一页就可以了),本文的方法思路同样可以运用于jquery、react、angular……等其他框架,因为简单,所以便捷。理解思路最重要,理解以后完全可以自己手写。
有时候看似复杂的问题,往往可以剑走偏锋,曲线救国!
好了下面直接上代码!
1、template部分:
1
2
3
4
5
6
7
8
9
10
11
12
|
<template> <div v- if = "!!dataList.length" > <div v- for = "(item,index) in dataList" > <!-- 数据展示列表 --> </div> <div id= "loadMore" v-show= "loadMore" >正在加载</div><!-- 第一次加载数据 --> <div id= "loadMoreing" v-show= "loadMoreing" >正在加载</div><!-- 上拉加载数据 --> <div id= "noMoreData" v-show= "loadMore?false:!loadMoreing" >已显示全部任务</div><!-- 所有数据加载完成 --> </div> <div id= "loadMoreing" v- else - if = "loadMoreing" >正在加载</div><!-- 页面渲染时 --> <div class = "noData" v- else >没有数据</div> </template> |
2、script部分
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
export default { data () { return { dataList: new Array, dataCurPage:1, // 数据页码 loadMore: true , // 第一次加载数据时的正在加载 loadMoreing: true , // 上拉加载数据时的正在加载 } }, mounted: function (){ let onScroll = window.addEventListener( 'scroll' , this .scrollRun); // 监听滚动 }, methods:{ getdataList: function (){ this .loadMoreing = true ; let _self = this ; $.ajax({ type: "post" , async: false , timeout : 10000, dataType: "json" , url: "" , data:{curPage:_self.dataCurPage}, success: function (data){ _self.loadMoreing = false ; // 接收到数据时,隐藏正在加载 if (!!data.dataList.length){ // 如果有数据 if (_self.dataCurPage==1){ // 当加载第1页数据时 _self.dataList = new Array; // 第1页清空数据 if (data.dataList.length>0){ // 如果第1页数据条数大于0 data.dataList.forEach( function (ele,i){ _self.dataList.push(ele); // 填充页面数据 }) _self.loadMore = true ; // 显示正在加载(在屏幕底部以外) } else { _self.loadMore = false ; // 没有数据则隐藏正在加载 } } else { // 当加载第2页及其以后的数据时 if (data.dataList.length>0){ data.dataList.forEach( function (ele,i){ _self.dataList.push(ele); // 填充页面数据 }) _self.loadMore = true ; // 显示正在加载(在屏幕底部以外) } else { _self.loadMore = false ; // 没有数据则隐藏正在加载 } } //如果总页数==当前页=>没有更多数据了 if (data.totalPage==_self.dataCurPage){ _self.loadMore = false ; _self.loadMoreing = false ; } } }, error: function (xhr,status,error){ console.log( "错误" ,xhr,status,error); if (status == "timeout" ){_self.loadMoreing = false ;weui.toast( '请求超时' , 800);} }, complete: function (){_self.loadMoreing = false ;} }) }, scrollRun: function (){ // 核心代码 if ( this .loadMore == true &&!!document.getElementById( "loadMore" )){ //如果总共有一页以上数据,才运行 let bodyWidth = document.body.offsetWidth; let bodyHeight = window.innerHeight*(375/bodyWidth); // 以6s屏幕为基准比例 let loadMoreTop = document.getElementById( "loadMore" ).getBoundingClientRect().top*(375/bodyWidth); //loadMore距离顶部的距离 if (bodyHeight-loadMoreTop>20){ //loadMore被拉出底部20px时 // console.log("bodyHeight",bodyHeight,"loadMoreTop",loadMoreTop,"差值",bodyHeight-loadMoreTop,"页码",this.dataCurPage+1); this .loadMore = false ; //停止运行scrollRun,否则会触发加载所有页面 this .getMoreList(_self.dataCurPage++); } } }, } } |
vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件的更多相关文章
- ASP.NET仿新浪微博下拉加载更多数据瀑布流效果
闲来无事,琢磨着写点东西.貌似页面下拉加载数据,瀑布流的效果很火,各个网站都能见到各式各样的展示效果,原理大同小异.于是乎,决定自己写一写这个效果,希望能给比我还菜的菜鸟们一点参考价值. 在开始之前, ...
- 关于Vue中页面(父组件)下拉,页面中的子组件加载更多数据的实现方法
一个项目中存在很多这种情况:父组件(页面)中的子组件需要做下拉加载更多的需求,但是这个下拉到底部的动作只能通过监控页面(父组件)来完成 这就需要父子组件之间的通信,代码如下: 1. 建立一个用于父子组 ...
- 微信小程序采坑之上拉触底加载更多和下拉刷新
小程序中加载更多数据一般都是触底刷新 有自带的函数: onReachBottom: function (){} 但是在使用时触发完全没有反应,后来尝试给外层加了一个高度,解决问题 仔细想想也是,没有设 ...
- listview下拉刷新 上拉(滑动分页)加载更多
最 近做的类似于微博的项目中,有个Android功能要使用到listview的向下拉刷新来刷新最新消息,向上拉刷新(滑动分页)来加载更多.新浪微博就是使用这种方式的典型.当用户从网络上读取微博的时候, ...
- h5 实现页面上拉加载更多数据
您好,您的上拉加载更多的代码来喽: html:(style部分:html部分:js部分--js部分主要就是监控上拉,调接口) //上拉加载更多css <style> .wait-loadi ...
- 微信小程序 - (下拉)加载更多数据
注意和后端配合就行了,前端也只能把数据拼接起来! 无论是下拉加载还是加载更多,一样的道理! 注意首次加载传递参数 注意每次加载数据数 wxml <view class='table-rank'& ...
- html ajax请求 php 下拉 加载更多数据 (也可点击按钮加载更多)
<input type="hidden" class="total_num" id="total" value="{$tot ...
- 小程序上拉加载更多数据(onReachBottom)
<!--pages/test/test.wxml--> <block wx:for="{{list}}" wx:key="item.id"&g ...
- wap 往下拉自动加载更多数据
var stop=true; $(window).scroll(function(){ totalheight = parseFloat($(window).height()) + parseFloa ...
随机推荐
- Everything的简单使用
1.Everythings下载地址: http://www.voidtools.com/ 下载完后直接解压,运行everything.exe即可打开使用: 2.基本设置 (1)去除不需要搜索的文件夹: ...
- IntelliJ IDEA 2017版 使用笔记(十一) Debug操作:IDEA 快捷键
调试功能; 缩短项目时间,调高阅读源码的能力. 一.添加断点,选中一行代码,双击即可生成断点(快捷键:ctrl+F8) 二.单步运行,快捷键:s ...
- BT1120时序,可以用于自测用
module bt1120_gen #( , , , , , )( input clk, input rst_p, // input [5:0] h_sync_pixcels, // input [5 ...
- Silverlight中图片显示
silverlight中显示一个图片有很多的中方法,xaml中的image控件或者自定编写程序来生成image控件. silverlight中显示的图片只能是Bitmap, JPG, PNG(64位颜 ...
- c#+web下载文件夹
最近公司在做工程项目,实现文件夹下载. 网上找了很久,发现网上的代码都有相似的问题,不过最终还是让我找到了一个符合的项目. 工程: 进行项目文件夹下载功能分析,弄清楚文件夹下载的原理,提供的数据支持. ...
- 1.8.2suspend与resume方法的缺点-独占
这两个方法使用不当,容易造成公共的同步对象的独占,使得其他线程无法访问公共的同步对象 测试 package com.cky.bean; /** * Created by edison on 2017/ ...
- nginx搭建简单的图片服务器
传统项目一般实现图片上传的话,都会在tomcat下面建立一个图片文件夹,上传成功后,用户可以直接访问, http://ip:port/project/images/xxx.jpg; 这样在用户量少的时 ...
- python advanced programming ( I )
函数式编程 函数是Python内建支持的一种封装,通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基 ...
- Mac使用终端安装Homebrew(brew)
Homebrew简称brew,OSX上的软件包管理工具,在Mac终端可以通过brew安装.更新.卸载软件. 1.打开终端直接输入下面指令回车: // ruby -e "$(curl -fsS ...
- python_列表、元组、字典、集合对比
列表.元组.字典.集合 列表.元组.字典.集合对比 比较项 列表 元组 字典 集合 类型名称 list tuple dict set 定界符 [] () {} {} 是否可变 是 否 是 是 是否有序 ...