Как добавить ссылку на маршрут к столбцу таблицы данных в laravel?

У меня есть система, которая показывает данные всех доступных пользователей системы с функцией поиска. Я сделал это с помощью пакета данных таблицы yajra. То, что я хочу, это если кто-то нажимает на строку пользователя, которая будет перенаправлять на этот профиль пользователя. Вот код контроллера

public function getUsers(){
    return DataTables::of(User::query()->with('profile'))->make(true);
}

public function index(){
    return view('alumni.list');
}

Это блейд-код для таблицы данных

$(document).ready( function () {
    $('#alumniTable').DataTable({
        "processing": true,
        "serverSide": true,
        "ajax": "{{ route('alumni-members') }}",
        columns: [
            { data: 'id' , name: 'id'},
            { data: 'name' , name: 'name'},
            { data: 'email' , name: 'email'},
            { data: 'student_id' , name: 'student_id'},
            { data: 'created_at' , name: 'created_at'},

        ]

    });
});

код маршрута:

Route::get('/alumni-members', 'AlumniController@index');
Route::get('users','AlumniController@getUsers')->name('alumni-members');

1 ответ

Если вам нужно добавить столбец ссылки на маршрут, чем добавить столбец в datatable

return Datatables::of(User::query()->with('profile'))
->addColumn('namelink', function ($user) {
    return '<a href="' . route('users.show', $user->id) .'">'.$user->name.'</a>'; 
})
->rawColumns(['namelink'])
->make(true);

а также добавить столбец в массиве столбцов:

$(document).ready( function () {
$('#alumniTable').DataTable({
    "processing": true,
    "serverSide": true,
    "ajax": "{{ route('alumni-members') }}",
    columns: [
        { data: 'id' , name: 'id'},
        { data: 'name' , name: 'name'},
        { data: 'email' , name: 'email'},
        { data: 'student_id' , name: 'student_id'},
        { data: 'created_at' , name: 'created_at'},
        {data: 'namelink', name: 'namelink', orderable: false, searchable: 
        false},

    ]

   });
});

Это сработало, но с небольшим изменением.

return datatables () -> of ($ d) -> addColumn ('ab_id', function ($ d) {return "

ab_id). "'>". $ d-> ab_id. "";
}) -> rawColumns(['ab_id']) -> make (true);

вместо маршрута я вызвал функцию URL, и она сработала

Другие вопросы по тегам