【发布时间】:2021-09-06 20:10:21
【问题描述】:
正如标题所说,当我尝试使用 laravel/ajax 和控制器内部的函数删除我的数据时出现错误:
控制器:
public function destroy($category_id) {
$category_delete = HmsBbrCategory::find($category_id);
$category_delete->delete();
return response()->json([
'status'=>200,
'message'=>'Category Deleted!',
]);
}
表单和 Ajax:
`delete_category` is the id that opens the delete modal and `delete_category_btn` is the button that will delete the data.
<button type="submit" class="btn btn-primary btn-block delete_category_btn"></i>Yes</button>
<button type="button" value="${cat.category_id}" class="delete_category btn btn-outline-secondary"><i class="fas fa-trash"></i> Delete</button>
$(document).on('click', '.delete_category', function (e) {
e.preventDefault();
//click this button(delete_category) to get the value(category_id)
var cat_id = $(this).val();
// alert(cat_id);
$('#delete_cat_id').val(cat_id);
$('#deleteCategoryModal').modal('show');
});
$(document).on('click', '.delete_category_btn', function (e) {
e.preventDefault();
var cat_id = $('#delete_cat_id').val();
// alert(cat_id);
//token taken from laravel documentation
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
});
$.ajax({
type: "DELETE",
url: "/clinical/bbr-category-configuration-delete/"+cat_id,
dataType: "dataType",
success: function (response){
// console.log(response);
$('#category_notif').addClass('alert alert-success');
$('#category_notif').text(response.message);
$('#deleteCategoryModal').modal('hide');
}
});
});
路线:
Route::delete('/bbr-category-configuration-delete/{category_id}', [BBRCategoryConfigurationController::class,'destroy']);
注意事项:
- 我继续在模态框内显示 category_id 以证明正在检索表。
删除按钮的第二个 ajax 函数:$(document).on('click', '.delete_category_btn', function (e),我也尝试使用alert(cat_id); 显示 id,以证明 id 在模态中仍然被识别:
即使 category_id 存在,尝试删除后检查页面仍然显示:
message: "Call to a member function delete() on null"
我能做些什么来解决这个问题?感谢您的帮助。
【问题讨论】:
-
如果你调用
findOrFail()而不是find会发生什么? -
检查您是否在控制器中获取 ID?
-
如果你找到 category_id 列,那么它应该是 $category_delete = HmsBbrCategory::where('category_id',$category_id)->first();否则在 db 中不存在记录。
标签: ajax laravel controller sql-delete http-status-code-500