下面是一个示例,在个人使用的过程中按自己需求进行更改

创建一个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. 微信小程序上拉加载下拉刷新

    微信小程序实现上拉加载下拉刷新 使用小程序默认提供方法. (1). 在xxx.json 中开启下拉刷新,需要设置backgroundColor,或者是backgroundTextStyle ,因为加载 ...

  2. 微信小程序 - 上拉加载下拉刷新

    点击下载示例:小程序 - 上拉刷新下拉加载

  3. 微信小程序上拉加载:onReachBottom详解+设置触发距离

    前端经常遇到上拉加载更多的需求,一般还涉及到翻页.小程序里已经给了下拉到底的触发方法onReachBottom(),这里记录下怎样使用这个方法实现下拉加载更多,有需要的直接看代码,有详细注释: 1.首 ...

  4. 微信小程序 - 上拉加载

    demo.wxml  文件 <view wx:for="{{listdata}}" wx:key="listdata" class='listitem'& ...

  5. 微信小程序~上拉加载onReachBottom

    代码: //页面上拉触底事件的处理函数 onReachBottom(e) { console.log("底部")// 滚动到页面执行 该 方法 wx.showToast({ tit ...

  6. 微信小程序上拉加载——分页

    wxml: <view class="page"> <scroll-view class="imageViewCss_1" scroll-y= ...

  7. 微信小程序 - 上拉加载更多组件

    详情用例看demo,点击下载示例:loadmore

  8. 微信小程序之下拉加载和上拉刷新

    微信小程序下拉加载和上拉刷新两种实现方法 方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新 首先要在json文件里设置window属性       ...

  9. 微信小程序下拉加载和上拉刷新两种实现方法

    方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新 首先要在json文件里设置window属性 设置js里onPullDownRefresh和onR ...

  10. 微信小程序之上拉加载更多

    loadmore 加载更多(分页加载) 当用户打开一个页面时,假设后台数据量庞大时,一次性地返回所有数据给客户端,页面的打开速度就会有所下降,而且用户只看上面的内容而不需要看后面的内容时,也浪费用户流 ...

随机推荐

  1. 题解:P8144 [JRKSJ R4] BBWWBB

    思路 分析题意可得,白方必定不会胜利,只能尽量让游戏无限进行下去.那么我们只考虑黑方能否胜利. 若想让戏能无限进行下去,必须满足以下条件. 白方先手. 若黑方先手必然可以吃掉一个白方,白方仅有一个棋子 ...

  2. CSP-S提高组数据结构算法模板大合集

    CSP-S 算法总结 2.2.1 基础知识与编程环境 无 2.2.2 C++ 程序设计 2 set/nultiset map/multimap deque/priority_queue STL 2.2 ...

  3. 《最新出炉》系列初窥篇-Python+Playwright自动化测试-58 - 文件下载

    1.简介 前边几篇文章讲解完如何上传文件,既然有上传,那么就可能会有下载文件.因此宏哥就接着讲解和分享一下:自动化测试下载文件.可能有的小伙伴或者童鞋们会觉得这不是很简单吗,还用你介绍和讲解啊,不说就 ...

  4. python统计班级学生

    python统计班级学生 如下场景: 假设我有一个学生类和一个班级类,想要实现的功能为:    执行班级人数增加的操作.获得班级的总人数:    学生类继承自班级类,每实例化一个学生,班级人数都能增加 ...

  5. 【Vue】02 Component 组件 & Axios

    Vue自定义组件: 不论任何注册组件的方式:template属性有且仅有一个根节点标签 就是说模版属性的标签只能有一个在最外面 <div id="container-element&q ...

  6. 暑假自学Java进度总结04

    一.今日所学: 1.下载并使用idea开发工具 1>了解idea的发展历史 2>尝试用idea编写代码 3>学习idea中的项目和模块操作 2.学习赋值运算符 加后赋值:" ...

  7. 【转载】 Python Pillow 和 cv2 图片 resize 速度的比较

    原文地址: https://zhuanlan.zhihu.com/p/91078855 -------------------------------------------------------- ...

  8. UE Websocket 通信

    项目中遇到UE需要对接Websocket协议接收实时数据. 所以需要实现一个Websocket Client的功能. 由于UE引擎已经集成了Websocket库(基于libwebsocket),可以通 ...

  9. redis集群之哨兵模式

    redis集群之哨兵模式 1.集群部署 安装配置可参考一下地址: https://www.cnblogs.com/zhoujinyi/p/5569462.html 2.与springboot集成 这里 ...

  10. posix是什么都不知道,还好意思说你懂Linux?

    Linux开发者越来越多,但是仍然有很多人整不明白POSIX是什么.本文就带着大家来了解一下到底什么是POSIX,了解他的历史和重要性. 一.什么是posix? 1. 概念 POSIX:可移植操作系统 ...