0
我使用的是laravel 5.2,Jquery 1.10和MYSQL 5.7。Laravel和jquery的数据表删除行
我在laravel中为我的消息模型使用RESTful服务。
我想呈现一个Jquery数据表中的消息列表,并提供一个删除按钮,每当按下时应该触发MessageController.php销毁方法,删除行然后重新加载消息索引页显示更新的数据表。
数据表最初是正确生成的,但删除按钮不会触发控制器上的删除方法。我假设我的ajax代码生成删除按钮必须是错误的。
在此先感谢您的帮助。
我的数据表中的AJAX脚本是 -
$(document).ready(function() {
$('#message_table').DataTable({
"searchable": false,
"ajax": {
"url": "/api/message",
"type": "POST",
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
},
"columns": [
{ "data": "id"},
{ "data": "subject",
"render": function(data,type,row,meta) {
return '<a href="/message/'+row.id+'">'+data+'</a>';
}
},
{ "data": "created_at",
"render": function (data, type, full, meta) {
// instantiate a moment object and hand it the string date
var d = moment(data);
var month = d.month() +1 < 10 ? "0" + (d.month() +1) : d.month() +1;
var day = d.date() < 10 ? "0" + (d.date()): d.date();
return month + "/" + day + "/" + d.year();
}
},
{"defaultContent": "null", "render": function(data,type,row,meta) {
return '<button action="' + $(location).attr('protocol') + $(location).attr('host') + '/message/'+row.id+ '"' + 'name="_method"' + 'method="post"' +'type="submit"' + 'value="Delete"'+'>'+ 'Delete</button>';
}
}
]
});
});
从最后一个函数删除按钮生成的HTML是─
<button action="http:localhost:8000/message/6" name="_method" method="post" type="submit" value="Delete">Delete</button>
的消息控制器删除方法 -
public function destroy($id)
{
Message::destroy($id);
return Redirect::route('message.index');
}
非常感谢。按钮HTML正在工作。现在在RouteCollection.php第219行异常中得到一个MethodNotAllowedHttpException异常。 405错误。奇怪的是,删除路线存在,并在另一个刀片上运行。 – user4074875
已排序。需要将csrf标记添加到删除http方法。 Laravel岩石! – user4074875