uni-app中页面的上拉加载与下拉刷新(中)

前面讲了基础的实现思路,这里继续补充一下具体的代码


滚动区域的具体实现代码

ini 复制代码
const sysInfo = uni.getSystemInfoSync()
this.window_height = sysInfo.windowHeight //窗口的可视高度

这里通过uni-app提供的获取设备信息的api拿到了整个可视区域的高度 赋值给变量window_height

ruby 复制代码
<!-- 内容区域 -->
<view class="sec1">
	<scroll-view 
	:style="'height:'+ (window_height-120) +'px'" 
	scroll-y="true" 
	@scrolltolower="handleScrollToLower">
	
		<view><uni-load-more :status="loading"></uni-load-more></view>
	</scroll-view>
</view>

实现区域滚动用的是uni-app提供的scroll-view组件

滚动区域的高度是通过 (window_height-120) +'px' 动态计算得到的,因为getSystemInfoSync获取到的数据返回的默认单位是px,所以这里后面使用的单位是px。而上面高度中的 120就是滚动区域上方一个固定的高度,不同的页面上方的高度可能会有所不同,视具体页面而定

请注意,虽然在小程序中为了自适应,很多单位都是用 rpx。但是,这种区域滚动上方占用高度的模块的高度还是建议使用 px的。这样的好处是,在任何设备上,这个高度都不会变。这样用可视高度减去这个具体的数值就是非常准确的滚动区域需要的高度


滚动区域设置完成以后,剩下的就是需要填充业务数据了。每一个项目中都会有分页,写的次数多了就会整理出一个固定的模板,这样以后哪里需要分页的时候,直接去拷贝现成的分页模板即可。提高开发效率,减少出错率。

分页拉取数据的业务的分析

分页加载数据的情况会有两种。

情况一 上拉需要加载更多数据的时候,此时需要拉取下一页的内容。

情况二 筛选条件改变 或者是触发下拉刷新操作的时候,此时需要清空已加载的数据,重新从第一页拉取符合条件得数据。这两种情况很多前端同学都是分开在两个方法中实现的。一个是刷新,一个是加载更多。但是这样写的问题是,两个方法中的代码逻辑非常的相似。我们尝试在一个方法中去实现,只是通过不同的参数去控制着 是加载更多数据 还是初始化分页数据。

分页拉取数据的业务代码

1 data中定义分页需要用到的一些变量

vbnet 复制代码
loading:'',   // more/loading/noMore
query_params:{
    pageNo:1,
    pageSize:3,
    typeOne:'',
    typeTwo:'',
    provinceId:'',
    cityId:'',
    areaId:'',
    rank:1,
},
list_data:[]

后续代码有详细的的解释

相关推荐
LaughingZhu1 小时前
Product Hunt 每日热榜 | 2026-04-05
前端·数据库·人工智能·经验分享·神经网络
SuperEugene2 小时前
Vue3 组件复用设计:Props / 插槽 / 组合式函数,三种复用方式选型|组件化设计基础篇
前端·javascript·vue.js
nFBD29OFC2 小时前
利用Vue元素指令自动合并tailwind类名
前端·javascript·vue.js
ISkp3V8b43 小时前
ASP.NET MVC]Contact Manager开发之旅之迭代2 - 修改样式,美化应用
前端·chrome
Highcharts.js3 小时前
高级可视化图表的暗色模式与主题|Highcharts 自适应主题配色全解
前端·react.js·实时图表
zk_one4 小时前
【无标题】
开发语言·前端·javascript
precious。。。5 小时前
1.2.1 三角不等式演示
前端·javascript·html
小陈工6 小时前
Python Web开发入门(十一):RESTful API设计原则与最佳实践——让你的API既优雅又好用
开发语言·前端·人工智能·后端·python·安全·restful
星空6 小时前
前段--A_2--HTML属性标签
前端·html
三万棵雪松6 小时前
【Linux 物联网网关主控系统-Web部分(一)】
linux·前端·嵌入式linux