bootstrapTable 多个表单新增删除行
时间: 2023-08-03 17:08:36 浏览: 109
如果你想在Bootstrap Table中实现多个表单的新增和删除行,可以使用Bootstrap Table的扩展插件editable。
首先,确保你已经引入了Bootstrap Table和editable插件的JS和CSS文件。然后,在表格头部添加一个新的列,用于操作新增和删除行:
```html
<th data-field="operate" data-formatter="operateFormatter">操作</th>
```
`operateFormatter`是一个自定义的格式化函数,它将在每行数据中添加一个操作列,用于新增和删除行。
接下来,在JavaScript代码中定义`operateFormatter`函数:
```javascript
function operateFormatter(value, row, index) {
return [
'<a class="add" href="javascript:void(0)" title="Add">',
'<i class="glyphicon glyphicon-plus"></i>',
'</a>',
'<a class="remove" href="javascript:void(0)" title="Remove">',
'<i class="glyphicon glyphicon-remove"></i>',
'</a>'
].join('');
}
```
该函数返回两个链接元素,一个用于新增行,另一个用于删除行。当用户点击“新增”链接时,会添加一个新的空行;当用户点击“删除”链接时,会删除该行。
最后,在JavaScript代码中添加以下事件监听器:
```javascript
$(function() {
$('#table').bootstrapTable({
onEditableSave: function(field, row, oldValue, $el) {
// 当表格的行数据被修改时触发此事件
}
});
// 新增行
$(document).on('click', '.add', function() {
var $table = $('#table');
$table.bootstrapTable('insertRow', {
index: $table.bootstrapTable('getData').length,
row: {}
});
});
// 删除行
$(document).on('click', '.remove', function() {
var $table = $('#table');
var index = $(this).parents('tr').data('index');
$table.bootstrapTable('removeByUniqueId', index);
});
});
```
在这段代码中,我们添加了两个事件监听器,一个用于新增行,另一个用于删除行。`insertRow`方法用于在表格中插入一行,`removeByUniqueId`方法用于删除指定的行。
注意,`onEditableSave`事件用于在编辑表格的行数据时触发,你可以在其中对数据进行保存操作。
希望这个示例可以帮助你实现多个表单的新增和删除行。
阅读全文