本文实例讲述了Laravel框架实现的批量删除功能。分享给大家供大家参考,具体如下:
1、HTML的内容
代码语言:javascript复制<tr
<th <input type="checkbox" class="checkbox-inline" onclick="checkAll(this)" </th // 用来全选
</tr
</thead
<tbody
@foreach ($keys as $key)
<tr
<td <input type="checkbox" class="ck checkbox-inline" name="item[]" value="{{ $key- id }}" </td // 复选框
</tr
@endforeach
<a style="font-size: 15px;" id="delAll" type="button" class="btn btn-primary" onclick="delKeys()" 批量删除</a
</tbody
2、js的内容
代码语言:javascript复制// 全选
var ck = $('.ck');
function checkAll(qx)
{
if (qx.checked) {
for (var i=0; i<ck.length; i ) { // 实现全选
ck[i].setAttribute("checked", "checked");
}
} else {
for (var i=0; i<ck.length; i ) { // 取消全选
ck[i].removeAttribute("checked");
}
}
}
// 批量删除
function delKeys()
{
var items = [];
for (var i=0; i<ck.length; i ) {
if (ck[i].checked) {
items.push(ck[i].value); // 将id都放进数组
}
}
if (items == null || items.length == 0) // 当没选的时候,不做任何操作
{
return false;
}
layer.confirm('您确定要删除我们吗?', {
btn: ['确定', '取消'],
}, function() {
$.post("{{ url('key/delAll') }}", {
"_token": "{{ csrf_token() }}",
"keys": items
}, function(data) {
if (data.status == 0) {
layer.msg(data.msg, { icon: 6});
location.href = location.href;
} else {
layer.msg(data.msg, { icon: 5});
}
});
}, function() {});
3、控制器中的内容
代码语言:javascript复制public function delAll(Request $request)
{
for ($i=0; $i<count($request['keys']); $i ) {
$res = Key::where('id', $request['keys'][$i])- update(['isDelete' = 1]); // 遍历删除
}
if ($res) {
$data = [
'status' = 0,
'msg' = '删除成功'
];
} else {
$data = [
'status' = 1,
'msg' = '删除失败'
];
}
return $data;
}
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。