当前位置: 首页 > news >正文

【PHP项目实战训练】——laravel框架的实战项目中可以做模板的增删查改功能(2)

在这里插入图片描述


👨‍💻个人主页:@开发者-曼亿点

👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅!

👨‍💻 本文由 曼亿点 原创

👨‍💻 收录于专栏:PHP程序开发


请添加图片描述

请添加图片描述

学生考勤签到系统 的增删查改

文章目录

    • 前言
    • 🎶一、查询功能
    • 🎶二、 修改功能
        • 结束语🥇


前言

  在现代 Web 开发中,构建具有增加、删除、查找和更新功能的应用程序是至关重要的。这些操作通常被统称为 CRUD 操作(创建、读取、更新和删除),是几乎所有 Web 应用程序的核心功能之一。在本教程中,我们将探索如何利用 Laravel 框架来实现这些功能,利用 Laravel 的强大功能和简洁的语法,快速构建一个完整的 CRUD 应用程序。

前提条件:

  了解基本的 PHP 编程知识。
  已经安装了 Composer 和 Laravel 开发环境。
  熟悉 Laravel 的基本概念,如路由、控制器、模型和视图。
  内容概述:

  创建数据库模型和迁移: 我们将定义数据库模型,并使用 Laravel 的迁移功能创建数据库表,确保数据库结构与应用程序需求一致。

  设置路由: 我们将设置路由,将 HTTP 请求映射到相应的控制器方法,建立客户端和服务器端之间的通信桥梁。

  编写控制器: 我们将编写控制器来处理业务逻辑,包括创建、读取、更新和删除操作,通过控制器将数据传递给视图或从视图接收用户输入。

  创建视图: 我们将创建视图来呈现用户界面,使用户可以执行 CRUD 操作,通过视图呈现数据、接收用户输入并显示相应的结果。


🎶一、查询功能


查询功能是是增删改查中最为复杂的,如果用原始的PHP写的话,还需添加jquery的容,主要用于查询到数据的展示,而laravel框架这对这个功能相对简化了不少,它采用的是在控制器中把查询到的数据传输到master.balde.php中,进行循环,将数据依次的展示。如果它在表单没输入,那么为NULL着将数据库对应的表的全部的信息展示。

(1)master.blade.php数据所接收展示部分的代码:


<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport"content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><link rel="stylesheet" href={{asset('/css/bootstrap.min.css')}}><script src={{asset('/js/jquery-3.6.1.min.js')}}></script><title>学生考勤签到系统</title><style>body {cursor: pointer;}</style>
</head>
<body>{{csrf_field()}}
<div class="container"><h1 style="text-align: center;margin: 30px 0">学生考勤签到系统</h1><form action="{{asset('select')}}" method="get" id="formInfo"><div>        <input type="text" name="classType" id="classType"><input  name="reset"  type="submit" value="查询"></div></form><form action="delectall.php" method="get"><div style="float: right"><input  onclick="return alert('确定重置?')" name="reset"  type="submit" value="重置"></div></form><table class="table table-hover" id="info"><thead><tr>         <th>班级</th><th>姓名</th><th>电话</th><th>状态</th><th>签到</th><th>操作</th></tr></thead><tbody>@foreach($data as $v)<tr>         <td>{{$v->class}}</td><td>{{$v->name}}</td><td>{{$v->tel}}</td><td>{{$v->zt}}</td><td><a type="submit" onclick="return confirm('是否已到场?')" href="{{asset('updata')}}?id={{$v->Id}}"><button>签到</button></a></td><td><button><a onclick="return confirm(' 确定要删除吗?')" href="{{asset('dela')}}?id={{$v->Id}}">删除</a></button></td></tr>@endforeach</tbody></table><div class="text-center"><button><a href="{{asset('addym')}}">添加学生</a></button></div>
</div>
<script></script>
</body>
</html>

(2)相关的路由代码的展示:

Route::get(“select”,[UserController::class,‘select’]);

(3)UserController.php控制器代码的展示:

public function select(Request $request){$where['class'] =$request['classType'];
if($where['class']==NUll){$data = DB::table("student")->get();return view("master",["data"=>$data]);
}else{$data = DB::table("student")->where('class', $where)->get();return view("master",["data"=>$data]);
}}

切记classType是查询表单中的的name


🎶二、 修改功能


  修改功它需要一个修改的输入框,与添加功能有点相似的输入框,修改功能也需要获取输入的表单的内容,其中注意在href中需要同时获取它的id主要是获取它的行的内容,修改如果失败,将弹出提示,修改失败。如果修改成功,将提示修改成功并进行页面刷新。
在这里插入图片描述

UserController.php代码:

public function updata(Request $request){
# 接收id 
$where['id'] = $request['id'];
# 接收新值 $res = DB::table('student')->where($where)->update(['zt'=>'已签']);
// dd($res);
if($res === 1){return redirect('show');
}else{return redirect('show');
}
}

结束语🥇

以上就是PHP程序设计
持续更新PHP程序设计教程,欢迎大家订阅系列专栏🔥PHP程序开发你们的支持就是曼亿点创作的动力💖💖💖
请添加图片描述

http://www.lryc.cn/news/359291.html

相关文章:

  • Kotlin 对象
  • 力扣 142题 环形链表Ⅱ 记录
  • 乐观锁 or 悲观锁 你怎么选?
  • 《庆余年算法番外篇》:范闲通过最短路径算法在阻止黑骑截杀林相
  • 大一C语言课设 服装销售系统 代码实现与项目总结
  • 从新手到专家:深入探索JVM垃圾回收--开端篇
  • R可视化:另类的柱状图
  • Docker的数据管理(数据卷+数据卷容器)
  • 字符串-至多包含K种字符的子串中最长子串(mid)
  • Docker从安装开始精通
  • MFC:初步理解序列化与反序列化(含代码实现)
  • python程序控制结构
  • 【GD32】04 - Timer定时器
  • Golang | Leetcode Golang题解之第123题买卖股票的最佳时机III
  • Leetcode2028. 找出缺失的观测数据
  • 如何在CentOS中合理划分磁盘空间以优化系统性能
  • 算法(十一)贪婪算法
  • Rust之函数式语言特性:迭代器和闭包(一):概述
  • 配置资源管理
  • unity2020打包webGL时卡进程问题
  • 云原生架构相关技术_3.无服务器技术
  • Leetcode:Z 字形变换
  • Python 3 判断文件是否存在
  • (深度学习记录)第TR3周:Transformer 算法详解
  • 谷神前端组件增强:自定义列
  • 31-ESP32-S3-WIFI篇-02 Event Group (事件标记组)
  • 构建企业级AI私有知识库
  • C语言王国——杨氏矩阵
  • 陪玩小程序都需要怎么做?
  • postgressql——子事务可见性判断 性能问题(8)