微信小程序上拉加载
下面是一个示例,在个人使用的过程中按自己需求进行更改
创建一个DataController控制器
php artisan make:controller DataController
创建一个Data的模型,并且在datas表里面创建两个字段,以name和description为例
php artisan make:model Data
下面是Datacontroller控制器里面的接口示例代码
<?php namespace App\Http\Controllers; use App\Models\Data;
use Illuminate\Http\Request; class DataController extends Controller
{
//
public function getData(Request $request)
{
$page = $request->query('page', 1);
$perPage = $request->query('perPage', 10); $data = Data::paginate($perPage, ['*'], 'page', $page); return response()->json($data);
}
}
下面是Data模型里面的代码
<?php namespace App\Models; use Illuminate\Database\Eloquent\Model; class Data extends Model
{
public $table='datas';
protected $fillable = [
'name',
'description',
// 其他字段...
];
}
给该接口一个路由
//微信小程序上拉加载
Route::get('data',[\App\Http\Controllers\DataController::class,'getData']);
接下来是微信小程序的代码,我给它加了一些样式,可以自行 更改
微信小程序的wxml代码
<view class="data-list">
<block wx:for="{{ dataList }}" wx:key="index">
<view class="data-item">
<view class="data-item-name">{{ item.name }}</view>
<view class="data-item-description">{{ item.description }}</view>
</view>
</block>
</view>
微信小程序的js代码
Page({
data: {
dataList: [], // 存储接口返回的数据
currentPage: 1, // 当前页码
perPage: 10, // 每页显示的数据数量
isLoading: false, // 是否正在加载数据
hasMore: true // 是否还有更多数据
},
onLoad: function() {
this.getDataList();
},
// 请求接口数据
getDataList: function() {
if (this.data.isLoading || !this.data.hasMore) {
return;
}
this.setData({
isLoading: true
});
wx.request({
//下面的url需要更换成自己的接口
url: 'http://www.day.com/index.php/data',
data: {
page: this.data.currentPage,
perPage: this.data.perPage
},
success: res => {
const newDataList = res.data.data;
const totalPage = res.data.last_page;
const currentPage = res.data.current_page;
this.setData({
dataList: this.data.dataList.concat(newDataList),
currentPage: currentPage + 1,
isLoading: false,
hasMore: currentPage < totalPage
});
},
fail: error => {
console.error('Failed to fetch data:', error);
this.setData({
isLoading: false
});
}
});
},
// 上拉加载更多
onReachBottom: function() {
this.getDataList();
}
});
下面是json的代码
{
"onReachBottomDistance": 50,
"usingComponents": {}
}
接下来是wxss代码
/* pages/page/page.wxss */
.data-list {
padding: 20rpx;
}
.data-item {
margin-bottom: 20rpx;
background-color: #f2f2f2;
padding: 10rpx;
border-radius: 5rpx;
}
.data-item-name {
font-size: 16px;
font-weight: bold;
}
.data-item-description {
margin-top: 5rpx;
color: #666;
}
在数据库里面datas表里面生成一些数据

这时候,就可以在微信开发者工具里面实现上拉加载的效果,下面是效果图


注意,以上是示例代码,在个人开发中按照自己的需求对其更改
微信小程序上拉加载的更多相关文章
- 微信小程序上拉加载下拉刷新
微信小程序实现上拉加载下拉刷新 使用小程序默认提供方法. (1). 在xxx.json 中开启下拉刷新,需要设置backgroundColor,或者是backgroundTextStyle ,因为加载 ...
- 微信小程序 - 上拉加载下拉刷新
点击下载示例:小程序 - 上拉刷新下拉加载
- 微信小程序上拉加载:onReachBottom详解+设置触发距离
前端经常遇到上拉加载更多的需求,一般还涉及到翻页.小程序里已经给了下拉到底的触发方法onReachBottom(),这里记录下怎样使用这个方法实现下拉加载更多,有需要的直接看代码,有详细注释: 1.首 ...
- 微信小程序 - 上拉加载
demo.wxml 文件 <view wx:for="{{listdata}}" wx:key="listdata" class='listitem'& ...
- 微信小程序~上拉加载onReachBottom
代码: //页面上拉触底事件的处理函数 onReachBottom(e) { console.log("底部")// 滚动到页面执行 该 方法 wx.showToast({ tit ...
- 微信小程序上拉加载——分页
wxml: <view class="page"> <scroll-view class="imageViewCss_1" scroll-y= ...
- 微信小程序 - 上拉加载更多组件
详情用例看demo,点击下载示例:loadmore
- 微信小程序之下拉加载和上拉刷新
微信小程序下拉加载和上拉刷新两种实现方法 方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新 首先要在json文件里设置window属性 ...
- 微信小程序下拉加载和上拉刷新两种实现方法
方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新 首先要在json文件里设置window属性 设置js里onPullDownRefresh和onR ...
- 微信小程序之上拉加载更多
loadmore 加载更多(分页加载) 当用户打开一个页面时,假设后台数据量庞大时,一次性地返回所有数据给客户端,页面的打开速度就会有所下降,而且用户只看上面的内容而不需要看后面的内容时,也浪费用户流 ...
随机推荐
- c++17 using继承所有构造函数
//使用using继承所有的构造函数 #include "tmp.h" #include <iostream> using namespace std; struct ...
- 记录荒废了三年的四年.net开发的第二次面试(进复试了)
这次面试的是小公司,深圳计通智能,面试分为初试和复试.使用腾讯视频会议完成.相比与上次面试,这次有所进步,进复试了.当然,这可能也与面试风格有关.这次面试着重与项目经历和技术,因此回答比较顺畅. 这一 ...
- docker redis集群实验
集群redis 分片+高可用+负载均衡 master + slave{1..5} 一个挂了另一个顶上 通过脚本创建6个redis配置文件 [root@docker ~]# for port in $( ...
- python __del__() 清空对象
python __del__() 清空对象 python垃圾回收机制:当一个对象的引用被完全清空之后,就会调用__del__()方法来清空这个对象 当对象的引用没有被完全清空时,代码如下: class ...
- MySQL常用语句(经常容易忘记)
MySQL常用语句 一.连接MySQL 格式: mysql -h <主机地址> -u<用户名> -p<用户密码> --port=<端口号> 1.例1:连 ...
- 【H5】05 高阶文字排版
摘自: https://developer.mozilla.org/zh-CN/docs/Learn/HTML/Introduction_to_HTML/Advanced_text_formattin ...
- 【JS】07 JS对象
所有事物都是对象 JavaScript 提供多个内建对象,比如 String.Date.Array 等等. 对象只是带有属性和方法的特殊数据类型. 布尔型可以是一个对象. 数字型可以是一个对象. 字符 ...
- 【Redis】02 Redis 搭建与操作
Redis的安装及启动停止 官网地址: https://redis.io/download 使用wget命令下载redis wget 下载地址 下载: [root@VM-0-7-centos ~]# ...
- 全网最适合入门的面向对象编程教程:30 Python的内置数据类型-object根类
全网最适合入门的面向对象编程教程:30 Python 的内置数据类型-object 根类 摘要: 在 Python 中,所有的类都直接或间接继承自一个根类,这个根类是Object.Object类是 P ...
- 计算机硕博如何快速毕业 —— “你们都说白狐是妖孽,它明明是祥瑞。” —— 请评价一下MDPI旗下的期刊质量如何?
MDPI是一个出版集团或者说是一个出版公司,其下辖多个开放期刊. 相关: https://www.zhihu.com/question/384813035/answer/1520065909 Sens ...