效果演示:

小程序上拉加载更多,下来刷新,在项目开发中是最常见,以下是一个简单的案例,供大家参考
wxml文件代码:
<!--index.wxml-->
<view class="out">
<!-- 项目 -->
<view class='left'>
<block wx:for="{{category}}">
<view class='nav-item active' wx:if="{{tags == item.id}}" data-id="{{item.id}}" bindtap="btn_cate">{{item.book_cate}}</view>
<view wx:else data-id="{{item.id}}" data-id="{{item.id}}" bindtap="btn_cate" class='nav-item'>{{item.book_cate}}</view>
</block>
</view>
<view class='right'>
<view class='book-list'>
<block wx:for="{{art}}">
<view class='book-item' bindtap='book_detail' data-id="{{item.id}}" bindtap="change_book_d">
<view class='bookimg'><image src='{{item.img}}' mode='widthFix'></image></view>
<view class='bookname'>{{item.name}}</view>
<view class='bookproject'>{{item.desc}}</view>
<view class='bookdesc'>+在线阅读</view>
</view>
</block>
</view>
</view>
</view>json文件代码:"enablePullDownRefresh": true, 开启小程序下拉刷新
{
"enablePullDownRefresh": true,
"usingComponents": {}
}js文件代码:
// pages/book/book.js
const app = getApp()
var page = 1; //设置默认页码
Page({
/**
* 页面的初始数据
*/
data: {
category: [],
tags: '3',
art: []
},
/**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
this.category(); //查询分类标签
this.getArt();
},
/**
* 生命周期函数--监听页面初次渲染完成
*/
onReady: function () {
},
/**
* 生命周期函数--监听页面显示
*/
onShow: function () {
},
/**
* 生命周期函数--监听页面隐藏
*/
onHide: function () {
},
/**
* 生命周期函数--监听页面卸载
*/
onUnload: function () {
},
/**
* 页面相关事件处理函数--监听用户下拉动作
*/
onPullDownRefresh: function () {
// 显示顶部刷新图标
wx.showNavigationBarLoading();
var that = this;
var tags = that.data.tags
page = 1;
wx.request({
url: app.AppUrl + '/get_book/cate_name/' + tags + '?page=' + page,
success: function (res) {
that.setData({
art: res.data.result,
})
// 隐藏导航栏加载框
wx.hideNavigationBarLoading();
// 停止下拉动作
wx.stopPullDownRefresh();
}
})
},
/**
* 页面上拉触底事件的处理函数
*/
onReachBottom: function () {
// 显示加载图标
wx.showLoading({
title: '玩命加载中',
})
// 页数+1
page = page + 1;
var that = this;
var tags = that.data.tags
wx.request({
url: app.AppUrl + '/get_book/cate_name/' + tags + '?page=' + page,
success: function (res) {
var oldData = that.data.art; //获取旧的数据
var newData = res.data.result; //获取旧的数据
that.setData({
art: oldData.concat(newData)
})
// 隐藏加载框
wx.hideLoading();
}
})
},
/**
* 用户点击右上角分享
*/
onShareAppMessage: function () {
},
// 查询分类标签
category: function () {
var that = this
wx.request({
url: app.AppUrl + '/getbookcate',
success(res) {
that.setData({
category: res.data.result,
})
}
})
},
// 获取文章
getArt: function () {
var tags = this.data.tags;
var that = this
wx.request({
url: app.AppUrl + '/get_book/cate_name/' + tags + '/page=' + page,
success(res) {
that.setData({
art: res.data.result,
})
}
})
},
// 点击获取分类文章
btn_cate: function (e) {
var tags = e.currentTarget.dataset.id
var that = this
that.setData({
tags: tags
})
page = 1;
wx.request({
url: app.AppUrl + '/get_book/cate_name/' + tags + '?page=' + page,
success(res) {
that.setData({
art: res.data.result,
})
}
})
}
})wxss样式文件代码:
page{
width: 100%;
height: 100%;
}
.out{
width:100%;
height:100%;
display: flex;
flex-direction:row-reverse;
}
.left{
width:18%;
height: 100%;
border-right:2rpx solid #ccc;
position: fixed;
left: 0px;
top: 0px;
}
.nav-item{
text-align: center;
font-size: 32rpx;
padding: 30rpx 0;
}
.active{
color: #fb7299;
border-left:3px solid #fb7299;
}
.right{
width:76%;
height: 100%;
padding: 20rpx;
text-align: center;
}
.book-list{
width: 100%;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.book-item{
width: 48%;
margin: 10rpx 0;
border:1rpx solid #ddd;
}
.bookimg{
width: 100%;
}
.bookimg image{
width: 100%;
display: block;
height: 612rpx;
}
.bookname{
overflow: hidden;
display: -webkit-box;
-webkit-box-orient: vertical;
text-overflow: ellipsis;
-webkit-line-clamp: 1;
font-size: 28rpx;
text-align: left;
padding: 5rpx 0;
color: #333;
font-weight: bold;
padding-left: 15rpx;
padding-right: 15rpx;
}
.bookproject{
overflow: hidden;
display: -webkit-box;
-webkit-box-orient: vertical;
text-overflow: ellipsis;
-webkit-line-clamp: 2;
font-size: 20rpx;
text-align: left;
padding: 3rpx 0;
color: #555;
padding-left: 15rpx;
padding-right: 15rpx;
}
.bookdesc{
overflow: hidden;
display: -webkit-box;
-webkit-box-orient: vertical;
text-overflow: ellipsis;
-webkit-line-clamp: 1;
text-align: right;
font-size: 24rpx;
color: #999;
padding-bottom: 22rpx;
padding-right: 15rpx;
padding-top: 12rpx;
}