在使用微信小程序时避免不了查询列表实现分页功能,在这里分享下使用croll-view实现上拉加载下拉刷新功能,如有不足请指出
-
创建commonPagination组件
-
wxml文件
<scroll-view class="scroll" style="{{style}}" scroll-top="{{scrollTop}}" scroll-y="true" refresher-enabled="{{true}}" bindrefresherrefresh="onPullDown" refresher-triggered="{{triggered}}" lower-threshold="{{50}}" bindscrolltolower="onPullUp"> <slot></slot> <view class="loadmore" hidden="{{!isLoadMoreing}}"> <view class="loadmore-icon"></view> <view class="loadmore-tips">正在加载</view> </view> <view wx:if="{{isNoMore}}" class="bot-line">我是有底线的</view> </scroll-view>
-
-
wxss文件
.scroll {
width: 100%;
height: 100%;}
.scroll ::-webkit-scrollbar {
width: 0;
height: 0;
color: transparent;
display: none;
}.loadmore {
width: 100%;
height: 100rpx;
display: flex;
align-items: center;
justify-content: center;
font-size: 14px;
}.loadmore-tips {
vertical-align: middle;
}.loadmore-icon {
margin: 0 5px;
width: 20px;
height: 20px;
vertical-align: middle;
-webkit-animation: weuiLoading 1s steps(12, end) infinite;
animation: weuiLoading 1s steps(12, end) infinite;
background: transparent url() no-repeat;
background-size: 100%;
}.bot-line {
color: #333;
height: 100rpx;
line-height: 100rpx;
white-space: nowrap;
text-align: center;
}
.bot-line::before,
.bot-line::after {
content: "";
display: inline-block;
width: 24vw;
height: 1rpx;
background-color: #ddd;
vertical-align: super;
margin: 0 36rpx;}
-
js文件
Component({
/** * 组件的属性列表 */ properties: { style: { type: String, value: '' }, _freshing: { type: Boolean, value: false }, _loadMoreing: { type: Boolean, value: false }, isLoadMoreing: { type: Boolean, value: false, observer: function (newVal) { console.log(newVal) } }, isNoMore: { type: Boolean, value: false }, triggered: { type: Boolean, value: false } }, /** * 组件的初始数据 */ data: { scrollTop: 0, }, /** * 组件的方法列表 */ methods: { // 下拉刷新 onPullDown(e) { this.triggerEvent('PullDown') }, // 上拉加载 onPullUp(e) { this.triggerEvent('PullUp') }, }
})
-
json文件
{
"usingComponents": {},
"component": true
} -
页面引用
-
wxml文件
<view class="box history-box"> <pagination bind:PullUp="handlePullUp" bind:PullDown="handlePullDown" _freshing="{{_freshing}}" _loadMoreing="{{_loadMoreing}}" isNoMore="{{isNoMore}}" triggered="{{triggered}}" isLoadMoreing="{{isLoadMoreing}}"> <view class="history-content-box" wx:for="{{historyList}}" wx:key="unique"> <view>{{item.name}}</view> </view> </pagination> </view>
-
-
wxss文件
.box {
height: 70vh;
position: absolute;
bottom: 0;
left: 0;
width: 100%;
background: rgba(240, 240, 240, 0.5);
backdrop-filter: blur(27.1828px);
border-radius: 40rpx 40rpx 0 0;
padding: 20rpx 50rpx;
box-sizing: border-box;
}
.history-box {
padding-top: 60rpx;
backdrop-filter: inherit;
background: rgba(215, 227, 235, 1);
}
.history-content-box {
width: 100%;
height: fit-content;
padding: 20rpx;
background-color: #fff;
border-radius: 20rpx;
box-sizing: border-box;
margin-bottom: 30rpx;
} -
js文件
// index.js
// 获取应用实例
const app = getApp()
import {
request
} from '../../utils/request'Page({
data: {_freshing: false, _loadMoreing: false, isNoMore: false, triggered: false, isLoadMoreing: false, pageIndex: 1, pageSize: 10, historyList:[] }, onLoad(option) { this.setData({ pageIndex: 1, historyList:[] }) this.getList() }, handlePullUp() { if (this.data._loadMoreing || this.data.isNoMore) return; this.setData({ isLoadMoreing: true, isNoMore: false, pageIndex: this.data.pageIndex + 1, _loadMoreing: true // pageIndex: res.length == 0 ? this.data.pageIndex : this.data.pageIndex + 1 }) this.getList('up') }, handlePullDown() { if (this.data._freshing) return; this._freshing = true this.setData({ _freshing: true, pageIndex: 1, isNoMore: false, triggered: true }) this.getList('down') }, getList(type) { let paramsData = { pageIndex: this.data.pageIndex, pageSize: 10 } if(this.data.pageIndex == 1) { this.setData({ historyList: [] }) } request("url", paramsData, "get").then(res => { console.log(res,'klklkl') let recordList = res.recordList || [] let list = this.data.historyList this.setData({ historyList: list.concat(recordList) }) console.log(this.data.historyList) if(type=='up') { this.setData({ isLoadMoreing: false, _loadMoreing: false }) } else { this.setData({ _freshing: false, pageIndex: 1, isNoMore: false, triggered: false }) } if(this.data.pageIndex == res.pageCount) { this.setData({ isNoMore: true }) } else { this.setData({ isNoMore: false }) } }).catch(error => { if (error === 401) { app.initLogin() } }) }
})
-
json文件
{
"usingComponents": {
"pagination":"/components/commonPagination/index"
},
"navigationStyle": "custom"
}