如何搜索我在 Laravel Yajra 数据表中添加的具有关系的列?
How to search a column that I added in Laravel Yajra Datatables with a relationship?
所以我正在使用 Yajra Datatables 来制作我的数据表。
我添加了如下所示的附加列,以便它可以显示关系中的用户名。
->addColumn('customer_name', function (Order $order){
return $order->user->name;
})
尽管此列出现在数据表中,但我无法搜索到它。下面是完整的函数代码:
public function viewDTPending(){
$store= Auth::user()->store;
$pending = Order::where('store', $store)->where('status', 'Pending')->orderBy('user_id')->groupBy('order_id', 'status', 'order_branch', 'user_id', 'created_at', 'updated_at');
return Datatables::of($pending)
->addColumn('customer_name', function (Order $order){
return $order->user->name;
})
->editColumn('created_at', function (Order $order){
return $order->created_at->diffForHumans();
})
->make(true);
}
下面是 ajax 代码:
<script>
$(function() {
$('#table').DataTable({
processing: true,
serverSide: true,
ajax: '{{ url('getPendingOrdersDT') }}',
columns: [
{ data: 'order_id', name: 'order_id' },
{ data: 'user_id', name: 'user_id' },
{ data: 'customer_name', name: 'customer_name' },
{ data: 'status', name: 'status' }
]
});
});
</script>
如何让它搜索 customer_name 列?
您必须输入 table 的名称以及列。
示例:姓名:'users.id'
我们用这个方法在同一个系统中搜索ajax
或简单代码:
$objects = Model::query()
->leftJoin('curs', 'cur.id', '=', 'model.cur_id')
->select([
'models.id',
'models.address',
'models.tag',
'curs.title_en',
]);
return Datatables::of($objects)
->addColumn('actions', function ($model) {
return 'action'
})
->make(true);
尝试预先加载:
$pending = Order::with('user:id,name')->where('store', $store)->where('status', 'Pending')->orderBy('user_id')->groupBy('order_id', 'status', 'order_branch', 'user_id', 'created_at', 'updated_at');
return Datatables::of($pending)
->addColumn('customer_name', function ($row){
return $row->user['name'];
})
所以我正在使用 Yajra Datatables 来制作我的数据表。
我添加了如下所示的附加列,以便它可以显示关系中的用户名。
->addColumn('customer_name', function (Order $order){
return $order->user->name;
})
尽管此列出现在数据表中,但我无法搜索到它。下面是完整的函数代码:
public function viewDTPending(){
$store= Auth::user()->store;
$pending = Order::where('store', $store)->where('status', 'Pending')->orderBy('user_id')->groupBy('order_id', 'status', 'order_branch', 'user_id', 'created_at', 'updated_at');
return Datatables::of($pending)
->addColumn('customer_name', function (Order $order){
return $order->user->name;
})
->editColumn('created_at', function (Order $order){
return $order->created_at->diffForHumans();
})
->make(true);
}
下面是 ajax 代码:
<script>
$(function() {
$('#table').DataTable({
processing: true,
serverSide: true,
ajax: '{{ url('getPendingOrdersDT') }}',
columns: [
{ data: 'order_id', name: 'order_id' },
{ data: 'user_id', name: 'user_id' },
{ data: 'customer_name', name: 'customer_name' },
{ data: 'status', name: 'status' }
]
});
});
</script>
如何让它搜索 customer_name 列?
您必须输入 table 的名称以及列。
示例:姓名:'users.id'
我们用这个方法在同一个系统中搜索ajax
或简单代码:
$objects = Model::query()
->leftJoin('curs', 'cur.id', '=', 'model.cur_id')
->select([
'models.id',
'models.address',
'models.tag',
'curs.title_en',
]);
return Datatables::of($objects)
->addColumn('actions', function ($model) {
return 'action'
})
->make(true);
尝试预先加载:
$pending = Order::with('user:id,name')->where('store', $store)->where('status', 'Pending')->orderBy('user_id')->groupBy('order_id', 'status', 'order_branch', 'user_id', 'created_at', 'updated_at');
return Datatables::of($pending)
->addColumn('customer_name', function ($row){
return $row->user['name'];
})