
本教程详细阐述如何利用php、mysql与ajax技术,在不刷新整个页面的前提下,实现待办列表中任务的删除功能。通过前端javascript发送异步请求至后端php脚本处理数据库操作,并动态更新页面dom,显著提升用户交互体验。
在现代Web应用中,用户对交互体验的要求越来越高。传统的表单提交和页面刷新方式在执行删除等操作时,会中断用户的当前浏览流程。通过结合PHP后端处理、MySQL数据库存储和AJAX(Asynchronous JavaScript and XML)前端技术,我们可以实现无刷新删除功能,让用户操作更加流畅。
一、核心原理概述
无刷新删除的核心在于AJAX。当用户点击删除按钮时:
前端JavaScript:捕获点击事件,获取待删除任务的唯一标识(ID)。AJAX请求:JavaScript通过AJAX向服务器发送一个异步请求,通常是POST请求,将任务ID传递给后端。后端PHP:接收请求,连接MySQL数据库,执行DELETE语句删除对应任务。后端响应:PHP脚本将操作结果(成功或失败)返回给前端。前端JavaScript:接收后端响应,根据结果动态更新页面DOM,例如,将已删除的任务从列表中移除,而无需重新加载整个页面。
二、数据库准备
首先,我们需要一个存储待办事项的数据库表。假设我们有一个名为 tasks 的表,结构如下:
CREATE TABLE `tasks` ( `task_id` INT AUTO_INCREMENT PRIMARY KEY, `task_name` VARCHAR(255) NOT NULL, `created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP);
三、前端页面构建 (HTML)
在主页面(例如 index.php)中,我们需要循环显示待办事项,并为每个事项提供一个删除按钮。关键在于为每个任务行添加一个唯一的标识,以便JavaScript能够精准定位和操作。
立即学习“PHP免费学习笔记(深入)”;
query("SELECT task_id, task_name FROM tasks ORDER BY task_id DESC");$tasks = $stmt->fetchAll();?> 我的待办列表 body { font-family: Arial, sans-serif; margin: 20px; } h1 { color: #333; } #task-list { border: 1px solid #ccc; border-radius: 5px; padding: 10px; max-width: 600px; margin-top: 20px; } .task-item { display: flex; align-items: center; padding: 10px 0; border-bottom: 1px solid #eee; } .task-item:last-child { border-bottom: none; } .task-name { flex-grow: 1; font-size: 1.1em; } .delete-btn { background-color: #dc3545; /* 红色 */ color: white; border: none; padding: 6px 12px; cursor: pointer; border-radius: 4px; font-size: 0.9em; transition: background-color 0.2s ease; } .delete-btn:hover { background-color: #c82333; /* 深红色 */ } .no-tasks { color: #666; text-align: center; padding: 20px; } 我的待办事项
<div class="task-item task-row-"> <button class="delete-btn" data-task-id="">删除 暂无待办事项。
微信扫一扫
支付宝扫一扫