PHP实践:用ThinkPHP6完整实现用户分页功能

在这里插入图片描述

🏆作者简介,黑夜开发者,CSDN领军人物,全栈领域优质创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月CSDN上海赛道top4。
🏆数年电商行业从业经验,历任核心研发工程师,项目技术负责人。
🏆本文已收录于PHP专栏:PHP进阶实战教程。
🎉欢迎 👍点赞✍评论⭐收藏

文章目录

  • 🚀一、背景
  • 🚀二、功能实现
    • 🔎2.1 安装ThinkPHP6
    • 🔎2.2 创建数据库表和填充数据
    • 🔎2.3 创建控制器和路由
    • 🔎2.4 创建模型
    • 🔎2.5 创建视图
    • 🔎2.6 运行项目并测试
  • 🚀三、总结


🚀一、背景

分页功能在Web开发中是一个非常常见的需求,特别是在处理大量数据时,为了提高用户体验和性能,将数据分页展示是必不可少的。ThinkPHP6作为一款流行的PHP框架,自带了强大的分页功能,本文将详细介绍如何使用ThinkPHP6实现分页功能。

在这里插入图片描述

🚀二、功能实现

🔎2.1 安装ThinkPHP6

首先,你需要在你的开发环境中安装ThinkPHP6。可以通过Composer来安装,运行以下命令:

composer create-project topthink/think tp6 --prefer-dist

这将会在当前目录下创建一个名为tp6ThinkPHP6的项目。

🔎2.2 创建数据库表和填充数据

接下来,我们需要创建一个用于分页的数据表,并填充一些测试数据。

假设我们创建了一个名为users的表,包含以下字段:

  • id:主键,自增
  • name:姓名
  • age:年龄

你可以使用以下SQL语句来创建这个表:

CREATE TABLE `users` (
  `id` INT(11) PRIMARY KEY AUTO_INCREMENT,
  `name` VARCHAR(255),
  `age` INT(11)
);

然后,可以插入一些测试数据:

INSERT INTO `users` (`name`, `age`) VALUES ('Tom', 20), ('Jerry', 25), ('Alice', 30), ('Bob', 35), ('Eve', 40);

🔎2.3 创建控制器和路由

在ThinkPHP6中,控制器负责处理用户请求,并返回相应的数据或视图。我们需要创建一个控制器来实现分页功能。

首先,在app目录下创建一个名为controller的文件夹。然后在controller文件夹下创建一个名为UserController.php的文件。

UserController.php中,编写以下代码:

<?php

namespace app\controller;

use think\Controller;
use app\model\User;

class UserController extends Controller
{
    public function index()
    {
        $page = request()->param('page', 1); // 获取当前页码,默认为第一页
        $limit = 10; // 每页显示的记录数

        $users = User::paginate($limit, false, ['query' => request()->param()]);

        $this->assign('users', $users);

        return $this->fetch();
    }
}

在上面的代码中,我们通过User模型的paginate方法来获取分页数据。paginate方法接受三个参数:每页显示的记录数、是否使用简洁模式和额外的查询参数。我们使用request()->param()来获取当前请求的所有参数,并将其传递给paginate方法。

然后,我们需要在route目录下的route.php文件中定义路由规则。打开route.php,并添加以下代码:

use think\facade\Route;

Route::get('user', 'user/index');

上面的代码表示当用户访问/user时,将会调用UserControllerindex方法。

🔎2.4 创建模型

模型是用于操作数据库的核心部分,我们需要创建一个名为User.php的模型。

app目录下的model文件夹中,创建一个名为User.php的文件,并编写以下代码:

<?php

namespace app\model;

use think\Model;

class User extends Model
{
    protected $table = 'users';
}

上面的代码定义了User模型对应的数据表为users

🔎2.5 创建视图

最后,我们需要创建一个用于显示分页数据的视图。

app目录下的view文件夹中,创建一个名为user的文件夹。然后在user文件夹中创建一个名为index.html的文件。

打开index.html,并编写以下代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>User List</title>
</head>
<body>
    <h1>User List</h1>

    <table>
        <tr>
            <th>ID</th>
            <th>Name</th>
            <th>Age</th>
        </tr>
        {volist name='users' id='user'}
        <tr>
            <td>{$user.id}</td>
            <td>{$user.name}</td>
            <td>{$user.age}</td>
        </tr>
        {/volist}
    </table>

    {$users->render()}
</body>
</html>

上面的代码中,我们使用{volist}标签来遍历users数组,并将每个用户的idnameage显示在表格中。

最后一行代码$users->render()表示输出分页导航栏,用于用户切换不同的分页页码。

🔎2.6 运行项目并测试

到此为止,我们已经完成了ThinkPHP6的分页功能实现。现在,我们可以运行项目并访问/user来查看分页效果了。

在命令行中,进入项目根目录,并运行以下命令启动内置Web服务器:

php think run

然后,在浏览器中访问http://localhost:8000/user,你将会看到一个包含分页功能的用户列表页面。

尝试点击分页导航栏上的不同页码,可以看到数据随之更新。

在这里插入图片描述

🚀三、总结

本文详细介绍了如何使用ThinkPHP6实现分页功能。通过创建控制器、模型和视图,以及定义路由规则,我们成功地展示了分页的用户列表,提高了用户体验和性能。

如果你正在开发一个大型数据驱动的应用程序,ThinkPHP6的分页功能将会是你的得力助手。它简单易用,且功能强大,使得处理大量数据变得轻松愉快。

在这里插入图片描述

推荐您阅读本专栏其他内容,PHP进阶实战教程,相信不会让您失望。如果你对上面的功能有疑问,随时欢迎与我交流。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/208369.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

太阳能路灯系统在道路照明中的应用

太阳能路灯作为一种极为科学和环保的光源利用形式&#xff0c;一直以来备受关注&#xff0c;但是&#xff0c;目前虽然有很多技术可以证明太阳能路灯的可行性&#xff0c;不过&#xff0c;如何真正的将太阳能路灯应用到道路照明之中&#xff0c;还是需要进行深入分析和探讨的。…

10个让UI设计更轻松的工具

UI设计软件对设计师来说非常重要。UI设计工具的使用是否直接影响到最终结果的质量&#xff0c;然后有人会问&#xff1a;UI界面设计使用什么软件&#xff1f;这里有一些UI设计师和那些对UI设计感兴趣的朋友列出了10个易于使用和免费的UI设计软件。 即时设计 即时设计是一款免…

腾讯云避坑——无法远程root登录

因为各种原因&#xff0c;最近需要使用腾讯云来代替阿里云。 但在ubuntu18/20的服务器中&#xff0c;我使用另一个电脑试图用scp命令来拷贝服务器中的一些文件&#xff0c;命令为: scp root服务器ip:文件目录 本地目录但一直显示密码错误。 原因是腾讯云ubuntu系统在创建时并不…

了解SpireCV如何利用G1吊舱进行点击跟踪

功能概述 SpireCV-SDK是一个专为智能无人系统打造的边缘实时感知SDK库。该库能够控制无人机的相机和吊舱&#xff0c;包括拍照、录像、推流等功能&#xff0c;并可以保存视频和进行推流。此外&#xff0c;SpireCV-SDK还集成了目标检测、识别与跟踪功能&#xff0c;以实现更智能…

关于加强型葡萄酒的类型有哪些?

加强型葡萄酒指的是在酿造过程中或酿造完后&#xff0c;添加酒精提高葡萄酒酒精度的葡萄酒&#xff0c;一般加强型葡萄酒的酒精度数都能达到15度以上。那么&#xff0c;云仓酒庄的品牌雷盛红酒分享加强型葡萄酒的类型有哪些呢&#xff1f; 云仓酒庄多品牌多代言运营模式&#…

量子光学的进步:光子学的“下一件小事”

量子光学是量子力学和光学交叉领域中发展迅速的一门学科&#xff0c;探索光的基本特性及其与物质在量子水平上的相互作用。通过利用光的独特特性&#xff0c;量子光学为通信、计算、密码学和传感等各个学科的变革性进步铺平了道路。 如今&#xff0c;量子光学领域的研究人员和工…

微信号被封了怎么办

13-7 常在河边走&#xff0c;哪有不湿鞋&#xff0c;做为经常用微信做电商客服的&#xff0c;或者经常在微信上和顾客谈钱的&#xff0c;总是会被微信后台重点关注&#xff0c;一不小心就有可能被封号。 如果遇到太倒霉的时候&#xff0c;永久封号了&#xff0c;这个时候微信…

基于SpringBoot的免税商品优选购物商城设计与实现

摘 要 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;通过科技手段提高自身的优势&#xff0c;免税商品优选购物商城当然也不能排除在外&#xff0c;随着购物商城的不断成熟&#xff0c;它彻底改变了过去传统的免税商品优选购物商城方式&…

FastDFS文件系统本地部署结合Nginx与内网穿透实现远程访问本地服务器

文章目录 前言1. 本地搭建FastDFS文件系统1.1 环境安装1.2 安装libfastcommon1.3 安装FastDFS1.4 配置Tracker1.5 配置Storage1.6 测试上传下载1.7 与Nginx整合1.8 安装Nginx1.9 配置Nginx 2. 局域网测试访问FastDFS3. 安装cpolar内网穿透4. 配置公网访问地址5. 固定公网地址5.…

python之pyqt专栏10-键盘事件

需求 通过按键盘的上下左右&#xff0c;移动button的位置。 UI界面设计 代码 # 导入sys模块 import sysfrom PyQt6.QtCore import Qt # PyQt6.QtWidgets模块中导入QApplication, QWidget from PyQt6.QtWidgets import QApplication, QWidget# untitled模块中导入Ui_Form类 f…

高等数学中的近似计算

今天来总结一下同济版高数中有关近似计算的例子&#xff0c;总的来说是如下的三种&#xff0c;有遗漏的话可以在评论区指出~ 目录 一.微分在近似计算中的应用 二.全微分在近似计算中的应用 三.函数的幂级数展开在近似计算的应用 一.微分在近似计算中的应用 本质原理是&am…

【Openstack Train安装】十三、创建实例

在先前的教程中&#xff0c;介绍了安装openstack及其相关组件的具体过程&#xff0c;本文介绍如何创建实例并完成访问。 在按照本教程操作之前&#xff0c;请确保完成以下配置&#xff1a; 【Openstack Train安装】一、虚拟机创建 【Openstack Train安装】二、NTP安装 【Op…

记一次SQL Server磁盘突然满了导致数据库锁死事件is full due to ‘LOG_BACKUP‘.

背景 最近我们的sql server 数据库磁盘在80左右&#xff0c;需要新增磁盘空间。还是处以目前可控的范围内&#xff0c;但是昨天晚上告警是80%&#xff0c;凌晨2:56分告警是90%&#xff0c;今天早上磁盘就满了。 经过 通过阿里云后台查看&#xff0c;磁盘已经占据99%&#xff0c…

LabVIEW在调用image.cpp或drawmgr.cpp因为DAbort而崩溃

LabVIEW在调用image.cpp或drawmgr.cpp因为DAbort而崩溃 出现下列问题&#xff0c;如何解决&#xff1f; 1. LabVIEW 程序因image.cpp或drawmgr.cpp中的错误而崩溃 2. 正在通过cRIO-9034运行独立的LabVIEW应用程序&#xff0c;但它因drawmgr.cpp中的错误而崩溃 …

程序员的侦探故事:调试中的逻辑与直觉

“在理论上&#xff0c;理论和实践是相同的。在实践中&#xff0c;它们不是。” — Yogi Berra 在技术的世界里&#xff0c;“bug”一词如今已成为编程语言中的常客&#xff0c;它代表着程序中的错误与缺陷&#xff0c;但你知道这个术语的起源吗&#xff1f; 它追溯到了1947年…

CV计算机视觉每日开源代码Paper with code速览-2023.11.28

点击CV计算机视觉&#xff0c;关注更多CV干货 论文已打包&#xff0c;点击进入—>下载界面 点击加入—>CV计算机视觉交流群 1.【图像分割】Stable Segment Anything Model 论文地址&#xff1a;https://arxiv.org//pdf/2311.15776 开源代码&#xff08;即将开源&…

文件重命名不再困难:文件智能化重命名技巧,告别手动提升效率

在日常工作中&#xff0c;经常会遇到要修改文件名的场景。传统的文件重命名方法往往要手动输入新的文件名&#xff0c;不仅耗时而且容易出错。为了提高效率&#xff0c;可以采用一些智能化重命名的技巧&#xff0c;告别手动修改文件名的繁琐过程&#xff0c;让文件重命名变得更…

SpringBoot+mysql+vue实现大学生健康档案管理系统前后端分离

一、项目简介 本项目是一套基于SpringBoot实现大学生健康档案管理系统&#xff0c;主要针对计算机相关专业的正在做bishe的学生和需要项目实战练习的Java学习者。 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目可以直接作为bishe使用。 项目都经过严格调试&#…

BootLoader升级过程讲解与串口升级案列

一、芯片选择 STM32F103RCT6 FLASH容量&#xff1a;512K RAM容量&#xff1a;48K 二、升级方式选择&#xff1a; 串口升级、网口升级、4G升级、SD卡升级等等。 1、SD卡升级属于升级文件事先存储在外部FLASH&#xff0c;不需要考虑获取升级文件的代码和升级文件存放的位置&am…

RabbitMQ学习一

RabbitMQ学习 RabbitMQ相关概念Virtual host数据隔离SpringAMQP第一种 基本消息模型第二种 WorkQueues模型第三种 发布订阅模型&#xff08;fanout交换机&#xff09;fanout交换机实例 第四种 Direct交换机direct交换机实例基于注解的方式声明——direct交换机 第五种Topic交换…