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 的参数,我需要找到附加到此特定页面的块。我的块数据库表看起来像这样
我怎样才能做到这一点?
我猜您必须在 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)