拉拉维尔数据表排序问题



我正在使用 Laravel - 亚吉拉的数据表 https://github.com/yajra/laravel-datatables-docs

它与单个表格完美配合,但是当我使用它的雄辩关系时,事情会变得严重。如下文所述,我在表中显示用户名, 它显示用户名非常好,但是当我尝试对用户进行排序或只是搜索时,它会给我一个错误的错误或显示SQL错误。

我有以下雄辩的模型

class Project extends Model{
public function client(){
return $this->belongsTo(Client::class);
}
}
class Client extends Model{
public function user(){
return $this->belongsTo(User::class);
}
}
class User extends Model{
}

.HTML

<table id="table">
<tbody>
<tr>
<td>Name</td>
<td>Start Date</td>
<td>Target</td>
<td>User</td>
</tr>
</tbody>
</table>
Javascript
$("#table").DataTable({
processing: true,
serverSide: true,
autoWidth:false,
ajax: '/projects',
columns:[
{ data: 'project_name', name: 'project_name' },
{ data: 'start_date', name: 'start_date' },
{ data: 'target', name: 'target' },
{ data: 'client.user.name', name: 'client.user.name' }
]
});

项目控制器

public function projects(){
return Datatables::of(Proejct::with(['client.user']))
->addColumn("client.user.name", function($row){
return $row->client->user->name;
})->make(true);
}

它不支持多级的雄辩关系排序或搜索。因此,您将获得数据,但无法对其进行搜索或排序。

您的代码似乎还可以,并且可以完美地用于单级。

下面是有关此问题的更多详细信息。 https://github.com/yajra/laravel-datatables/issues/993

返回$row->client((->user((->name;

最新更新