Laravel SortableJS AJAX - 如何重新排列顺序

Rai*_*aan 2 javascript php ajax jquery-ui-sortable laravel

我刚刚在我的 Laravel 项目中实现了 SortableJS,并想重新排列一些元素的顺序。我有一个“块”列表,它们都有一个“订单”的数据库字段,它是一个整数。我根据“订单”字段的值以降序显示这些块。

现在我想使用 Ajax 用 SortableJS 更新这些值。我怎样才能做到这一点?

目前,我有一个简单的列表

<div class="block-order-list">
   @foreach($blocks as $block)
     <div class="list-group-item"><i class="far fa-arrows handle mr-3"></i> {{$block->name}}</div>
   @endforeach
</div>
Run Code Online (Sandbox Code Playgroud)

并像这样调用 Ajax 请求:

$('.block-order-list').sortable({
            animation: 150,
            handle: '.handle',
            store: {
                set: function (sortable) {
                    let order = sortable.toArray();
                    console.log(order);
                    $.ajaxSetup({
                        headers: {
                            'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
                        }
                    });
                    $.ajax({
                        url: '{{ route('change_order', ['url', $page->url]) }}',
                        type: 'POST',
                        data: order,
                        success: function(data){
                            console.log(data)
                        }
                    })
                }
            }
        });
Run Code Online (Sandbox Code Playgroud)

到我的 PageController 其中包含

 public function changeOrder($data)
    {

        return $data;
    }
Run Code Online (Sandbox Code Playgroud)

该请求现在只返回一个字符串,说明url我觉得奇怪。在 ajax 请求的 url 中,我提供了一个名为 URL 的参数,我需要找到附加到此特定页面的块。我的块数据库表看起来像这样

在此处输入图片说明

我怎样才能做到这一点?

Vin*_*aux 5

我猜您必须在 HTML 列表中使用 ID:

<div class="block-order-list">
   @foreach($blocks as $block)
     <div class="list-group-item" data-id="{{ $block->id }}>
          <i class="far fa-arrows handle mr-3"></i> {{ $block->name }}
     </div>
   @endforeach
</div>
Run Code Online (Sandbox Code Playgroud)

然后在您的 JS 中,构建一个 ID => order 的数组:

let order = {};
$('.list-group-item').each(function() {
    order[$(this).data('id')] = $(this).index();
});
Run Code Online (Sandbox Code Playgroud)

然后在你的 ajax 调用中:

 $.ajax({
    url: '{{ route('change_order', ['url', $page->url]) }}',
    type: 'POST',
    data: {order: order},
    success: function(data){
        console.log(data)
    }
})
Run Code Online (Sandbox Code Playgroud)

在您的控制器中:

public function changeOrder(Request $request)
{
    foreach($request->get('order') as $id => $order) {
        Block::find($id)->update(['order' => $order]);
    }
}
Run Code Online (Sandbox Code Playgroud)