uniapp移动端实现上拉加载(分页),下拉刷新

上拉加载

在需要实现该功能的页面写入 onReachBottom()方法函数,该方法与 onLoad() 方法同级,需在在data中声明 pageNo和pageSize以及总条数,具体代码如下:

html 部分

javascript 复制代码
<-- html部分  引入uview 使用uview加载效果 -->

        <div v-if="loading" style='display: flex;justify-content: center;margin-top: 50rpx;'>
			<u-loading-icon></u-loading-icon>
		</div>
		

javascript 部分

javascript 复制代码
   data() {
			return {				
				loading: true,
				//页码
				pageNo: 1,
				//页容量
				pageSize: 10,
				//总条数
				total: 0,
				List:[]
			}
		},
      onLoad() {  },
	  // 上拉加载数据
	  onReachBottom() {
	  //判断 如果页码*页容量大于等于总条数,提示该页数据加载完毕
			if (this.pageNo * this.pageSize >= this.total){
				uni.$u.toast('数据加载完毕')
				return
			}
			//并且让页码+1,调用获取数据的方法获取第二页数据
			this.pageNo++
			//此处调用自己获取数据列表的方法
			this.Getlist()
		},
		methods: {
		
             // 获取数据列表
			Getlist() {
			   //设置加载效果
				this.loading = true
				//调起接口 将页码入参
				Api({
					params: {
						pageNo: this.pageNo,
						pageSize: this.pageSize
					}
				}).then(res => {
				//如果获取数据成功 将数据赋值给事先声明的数组
					if (res.success) {
						this.List = res.result.records
						//判断 如果获取的数据的页码不是第一页,就让之前赋值获取过的数组数据 concat连接 刚获取的第n页数据
						if (res.result.pages != 1) {
							this.List = this.List.concat(res.result.records)
						} else {
							this.List = res.result.records
						}
						//将获取的总条数赋值
						this.total = res.result.total

					}
					this.loading = false
				})
			},




        }

		

遇到的问题

屏幕上滑onReachBottom不触发

解决

如果你在使用 onReachBottom 的时候没有触发,就看看那个页面有没有出现滚动条,没有就不会触发

因为 view 没有高度(百分百也不行),然后就调用不到 onReachBottom 这个钩子

javascript 复制代码
page {
		height: initial;
		overflow-y: initial;
		min-height: 100vh;
	}

其实配不配置 onReachBottomDistance 都没关系的(个人觉得)

initial 关键字用于设置 CSS 属性为它的默认值

initial 关键字可用于任何 HTML 元素上的任何 CSS 属性
官网
initial
参考原文

下拉刷新

打开项目根目录中的 pages.json 配置文件,在需要开始下拉刷新功能的页面路径下添加 或者在 globalStyle 中全局添加 enablePullDownRefresh 为true,开始下拉刷新。代码如下:

某个页面开启:

javascript 复制代码
{
			"path": "pages/views/index",
			"style": {
				"navigationBarTextStyle": "white",
				"navigationBarBackgroundColor": "#6495ed",
				"navigationBarTitleText": "首页",
				
				"enablePullDownRefresh": true

			}

		},

全局开启:

javascript 复制代码
"globalStyle": {
		"navigationBarTextStyle": "black",
		"navigationBarTitleText": "uni-app",
		"navigationBarBackgroundColor": "#F8F8F8",
		"backgroundColor": "#F8F8F8",
		
		"enablePullDownRefresh": true,


		}

	},

同样,在与 onLoad() 方法同级处添加以下代码:

javascript 复制代码
// 下拉刷新
		onPullDownRefresh() {
			console.log('刷新')
			//下拉之后 重新调用获取数据的方法
			this.Getlist()
			//获取之后 一定要 调用uni.startPullDownRefresh() 停止刷新!!!否则将会一直处于刷新状态			
			uni.startPullDownRefresh()
		},

参考原文

相关推荐
瑶琴AI前端1 小时前
uniapp实现H5和微信小程序获取当前位置(腾讯地图)
微信小程序·小程序·uni-app
耶啵奶膘7 小时前
uniapp-是否删除
linux·前端·uni-app
断墨先生13 小时前
uniapp—android原生插件开发(3Android真机调试)
android·uni-app
guai_guai_guai15 小时前
uniapp
前端·javascript·vue.js·uni-app
阿伟来咯~20 小时前
一些 uniapp相关bug
uni-app·bug
瑶琴AI前端1 天前
uniapp组件实现省市区三级联动选择
java·前端·uni-app
mosen8681 天前
Uniapp去除顶部导航栏-小程序、H5、APP适用
vue.js·微信小程序·小程序·uni-app·uniapp
尚梦1 天前
uni-app 封装刘海状态栏(适用小程序, h5, 头条小程序)
前端·小程序·uni-app
尚学教辅学习资料2 天前
基于SSM+uniapp的营养食谱系统+LW参考示例
java·uni-app·ssm·菜谱
Bessie2342 天前
微信小程序eval无法使用的替代方案
微信小程序·小程序·uni-app