fastadmin表格操作按钮btn-dialog、btn-addtabs 遇到的坑

在使用Fastadmin开发时,尝试修改表格操作按钮颜色,将btn-dialog错误地替换为了btn-warning,结果导致编辑按钮不再弹出对话框。正确做法是为a标签添加btn-dialog以实现弹窗效果。此外,btn-addtabs用于打开新选项卡。这是一个关于Fastadmin自定义类名和功能的小教训。

好久没写博客了。今天用fastadmin在实现表格操作按钮的时候,遇到了一个坑,耽误了我一下午的时间,给大家分享下,以免踩坑。

下图标注所示,本来我是要改按钮颜色,但是却把"btn-dialog"直接改成了我想要的"btn-warning" ,导致点击编辑按钮一直不是弹窗的效果。a标签添加btn-dialog就可以出现弹框。添加btn-addtabs弹出新的选项卡这是fastadmin自己定义的。
在这里插入图片描述

就说到这里吧,估计也不会有人跟我一样,这样操作改出了这个问题~~~

### 解决方案 为了防止 FastAdmin 中 `btn-dialog` 按钮重复触发弹出对话框,可以采取以下措施: #### 方法一:禁用按钮直到操作完成 通过 JavaScript 或 jQuery,在点击事件发生时立即禁用按钮,待异步请求完成后重新启用。 ```javascript $('.btn-dialog').on('click', function() { var $this = $(this); $this.prop('disabled', true); // 禁用按钮 $.ajax({ url: $this.attr('href'), type: 'GET', success: function(response) { // 处理响应逻辑... // 对话框关闭后的回调函数内重置按钮状态 $('#yourDialogId').on('hidden.bs.modal', function () { $this.prop('disabled', false); }); }, error: function(xhr, status, error) { console.error(error); alert('Error occurred'); $this.prop('disabled', false); } }); return false; }); ``` 此方法确保每次点击后都会暂时阻止再次点击,直至当前的操作完全结束[^1]。 #### 方法二:使用一次性标记 引入一个全局变量作为标志位来控制是否允许执行打开新对话框的动作。当首次点击时设置该标志为真,并在成功处理完一次完整的交互流程后再将其恢复成假的状态。 ```html <script> var canOpenNewDialog = true; $(document).ready(function(){ $('.btn-dialog').on('click', function(e){ e.preventDefault(); if (!canOpenNewDialog) return; canOpenNewDialog = false; // 执行打开对话框的相关代码... // 假设这里是你定义好的关闭对话框的方法 $('#myModal').on('hidden.bs.modal', function (e) { canOpenNewDialog = true; }) }); }) </script> ``` 这种方法同样能有效避免短时间内连续多次触发相同行为的情况出现[^3]。 #### 方法三:利用 ZK 的特性 如果项目基于 ZK 框架构建,则可以直接借助其内置机制实现防抖动效果。例如,在创建模态窗口之前先判断是否存在已存在的实例;如果有则不再新建而是直接调用现有实例的 `.doModal()` 方法即可[^2]。 ```java if(window != null && !window.isOpen()){ window.doModal(); } else { Window window = (Window) Executions.createComponents("/path/to/dialog.zul", null, null); window.setClosable(true); window.setTitle("Title"); window.setWidth("80%"); window.setHeight("60%"); window.setPosition("center"); window.setBorder("normal"); window.setVisible(true); } ``` 以上三种策略可以根据具体应用场景灵活选用或组合应用以达到最佳用户体验和性能表现。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

运营侠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值