繁体   English   中英

删除Laravel中的多个记录

[英]Delete multiple records in laravel

只删除一条记录,我意识到这个ajax

var borrar = confirm("¿Realmente desea eliminarlo?");
          if (borrar) 
          {
            var token = document.getElementById('token').value;
            $.ajax({
                headers: {'X-CSRF-TOKEN': token},
                dataType: "json",
                data: {radicado: radicado},
                url:   ip+'/eliminarRadicado/delete/'+radicado,
                type:  'get',
                beforeSend: function(){
                    },
                success: function(respuesta){
                    alert(respuesta);
                },
                error: function(xhr,err){ 
                    alert("Error");
                }
            });
          }

它通过$ get发送我删除文件并运行此路由的记录的ID:

Route::get('eliminarRadicado/delete/{id}', 'RadicadoController@destroy');

最终由驱动程序执行并执行删除功能

public function destroy($id)
{
    \App\Radicado::destroy($id);
    return response()->json(['Documento eliminado']);
}

这不像删除我发送的多个记录(id)。 有任何想法吗 ?

您不应该使用GET动词发送删除请求。 相反,您应该使用语义正确的DELETE动词。


使用您当前的方法,发送X-CSRF-TOKEN标头不会执行任何操作,因为Laravel不会检查CSRF令牌的读取请求( GETHEAD )。 相反,应使用DELETE请求将要删除的所有ID作为参数传递,如下所示:

var ids = [1, 10, 17]; // Use your own logic to set the array of the IDs here

$.ajax({
    headers : {'X-CSRF-TOKEN': token },
    dataType: "json",
    data    : { ids: ids },                   // Pass IDs array
    url     : ip + '/eliminarRadicado/delete',
    type    : 'delete',                       // Send a delete request

    beforeSend: function () {
    },

    success: function (respuesta) {
        alert(respuesta);
    },

    error: function (xhr, err) { 
        alert("Error");
    }
});

然后将您的路线定义更改为:

Route::delete('eliminarRadicado/delete', 'RadicadoController@destroy');

destroy控制器方法中,使用通过请求接收的ID数组:

use Illuminate\Http\Request;

...

public function destroy(Request $request)
{
    \App\Radicado::destroy($request->input('ids'));

    return response()->json(['Documento eliminado']);
}

现在,您可以传递一个或多个ID的数组,以使用同一请求将其删除。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM