本文介绍如何在 bootstrap 模态框中,基于当前记录的 status 字段值(如 "pending" 或 "approved")自动禁用或启用 approve 提交按钮,使用 jquery 实现简洁可靠的前端控制逻辑。
在管理后台的预约系统中,常需通过模态框(Modal)展示并更新预约记录。为防止误操作,通常要求:仅当状态为 "Approved" 时才允许点击 Approve 按钮;若状态为 "Pending"(或其他非批准状
态),则按钮应默认禁用且不可提交。
实现该功能无需后端干预,纯前端即可完成——关键在于:在模态框打开时,动态读取当前记录的 status 值,并据此设置按钮的 disabled 属性。
确保模态框与数据源绑定
假设你使用 DataTables 或普通 HTML 表格,每行末尾有 .updatebtn 类按钮用于触发模态框。点击时需将该行所有字段(含 status)传入模态框对应输入框。
在模态框初始化时判断并禁用按钮
使用 jQuery 监听表格行内 .updatebtn 的点击事件,在填充表单字段后,立即检查 #status 输入框的值,并控制 #updatedata 按钮状态:
$(document).ready(function() {
$('#datatableid tbody').on('click', '.updatebtn', function() {
$('#updatemodal').modal('show');
const $tr = $(this).closest('tr');
const data = $tr.children('td').map(function() {
return $(this).text().trim();
}).get();
// 填充表单字段(索引按表格列顺序对应)
$('#update_id').val(data[0]);
$('#date').val(data[1]);
$('#time').val(data[2]);
$('#username').val(data[3]);
$('#contact').val(data[4]);
$('#bookpet_id').val(data[5]);
$('#service_id').val(data[6]);
$('#complaint').val(data[7]);
$('#status').val(data[8]);
// ✅ 核心逻辑:仅当 status === 'Approved' 时启用按钮
const isApproved = data[8] === 'Approved';
$('#updatedata').prop('disabled', !isApproved);
});
});? 注意:data[8] 对应表格第 9 列(从 0 开始计数),请根据你实际表格中 status 所在列调整索引。建议在 console.log(data) 后验证顺序。
const validStatuses = ['Approved'];
$('#updatedata').prop('disabled', !validStatuses.includes(data[8]));通过以上方式,你就能在不修改后端逻辑的前提下,快速、可靠地实现“按状态动态启用/禁用 Approve 按钮”的交互体验,兼顾安全性与用户友好性。