键值组件动态渲染后追加按钮失效问题
键值组件(Fieldlist)使用 JavaScript 动态渲染后,追加的按钮可能会失效,点击没有反应。为了解决这个问题,可以按照以下步骤操作:
$(document).on('click', '.btn-append', function(event) { event.preventDefault(); // 追加新元素的逻辑 });
$(document).on('click', '.btn-remove', function(event) { event.preventDefault(); $(this).closest('tr').remove(); });
以上步骤可以有效解决动态渲染后追加按钮失效的问题。具体实现细节请参考以下代码示例:
<table class="table table-responsive fieldlist"> <thead> <tr> <td>ID</td> <td>Chinese name</td> <td>English name</td> <td>Number of pieces</td> <td>Volume</td> <td>Gross Weight</td> <td>Value (USD)</td> <td>Operate</td> </tr> </thead> <tbody> <tr> <td colspan="8"> <a href="javascript:;" class="btn btn-sm btn-success btn-append"><i class="fa fa-plus"></i> Append</a> </td> </tr> </tbody> </table>
$(document).ready(function() { $(document).on('click', '.btn-append', function(event) { event.preventDefault(); $('table.fieldlist').append('<tr><td>New ID</td><td>New Chinese name</td><td>New English name</td><td>New Number of pieces</td><td>New Volume</td><td>New Gross Weight</td><td>New Value (USD)</td><td><a href="javascript:;" class="btn btn-sm btn-danger btn-remove"><i class="fa fa-times"></i> Remove</a></td></tr>'); }); $(document).on('click', '.btn-remove', function(event) { event.preventDefault(); $(this).closest('tr').remove(); }); });