كما قال العنوان ، كيفية إنشاء صف تابع للحصول على معلومات إضافية مثل هذا المثال باستخدام هذه المكونات الإضافية: د
https://www.datatables.net/examples/api/row_details.html
تحياتي الحارة
أهلا،
ما عليك سوى اتباع ما يظهره هذا الرابط على جانب جافا سكريبت ويجب أن يعمل كما هو متوقع. الاختلاف الوحيد في هذا المثال هو أنه سيتعين عليك استخدام البرنامج النصي من جانب الخادم لـ DT.
من ناحية أخرى ، أعتقد أنني سأضيف هذا إلى التطبيق التجريبي الذي كنت أعمل عليه مؤخرًا. سنبقيك منشوراً هنا عندما يكون العرض التوضيحي لتفاصيل الصف جاهزًا. تحقق أيضًا من ذلك لمعرفة كيفية استخدام الحزمة في سيناريوهات معينة.
هتافات!
يوجد أدناه مثال على برنامج نصي يمكنك استخدامه لتنفيذ ذلك.
var table = $('#users-table').DataTable({
processing: true,
serverSide: true,
ajax: '{{ url("users-data") }}',
columns: [
{
"className": 'details-control',
"orderable": false,
"data": null,
"defaultContent": ''
},
{data: 'id', name: 'id'},
{data: 'name', name: 'name'},
{data: 'email', name: 'email'},
{data: 'created_at', name: 'created_at'},
{data: 'updated_at', name: 'updated_at'}
],
order: [[1, 'asc']]
});
// Add event listener for opening and closing details
$('#users-table tbody').on('click', 'td.details-control', function () {
var tr = $(this).closest('tr');
var row = table.row( tr );
if ( row.child.isShown() ) {
// This row is already open - close it
row.child.hide();
tr.removeClass('shown');
}
else {
// Open this row
row.child( format(row.data()) ).show();
tr.addClass('shown');
}
});
/* Formatting function for row details - modify as you need */
function format ( d ) {
// `d` is the original data object for the row
return '<table class="table">'+
'<tr>'+
'<td>Full name:</td>'+
'<td>'+d.name+'</td>'+
'</tr>'+
'<tr>'+
'<td>Email:</td>'+
'<td>'+d.email+'</td>'+
'</tr>'+
'<tr>'+
'<td>Extra info:</td>'+
'<td>And any further details here (images etc)...</td>'+
'</tr>'+
'</table>';
}
على وحدة التحكم الخاصة بك
public function getUsersData()
{
$users = User::select(['id', 'name', 'email', 'created_at', 'updated_at']);
return Datatables::of($users)->make(true);
}
تم إضافة مثال تفاصيل الصف على التطبيق التجريبي ، فقط قم بفحصه لترى كيف يعمل. شكرا!
لست متأكدًا من الخطأ js ولكن يجب أن يكون لديك شيء مثل هذا في البرنامج النصي الخاص بك. باستخدام قالب شريط المقبض ثم قم بتمرير البيانات template(row.data())
.
var template = Handlebars.compile($("#details-template").html());
// Add event listener for opening and closing details
$('#users-table tbody').on('click', 'td.details-control', function () {
var tr = $(this).closest('tr');
var row = table.row( tr );
if ( row.child.isShown() ) {
// This row is already open - close it
row.child.hide();
tr.removeClass('shown');
}
else {
// Open this row
row.child( template(row.data()) ).show();
tr.addClass('shown');
}
});
نعم آسف ، الكود يعمل ، أحتاج فقط إلى حذف البيانات الأخرى بعد "الإجراء" ،
يمكن النقر فوق التفاصيل على الجانب الأيسر من الجدول ، والمشكلة هي أن الرمز لا يظهر .. هل قمت بالفعل بتنزيل الزر من العرض التوضيحي الخاص بك على الرغم من:؟
أعتقد أن ملف css لم يتم إدراجه بعد ..
سيئتي ، أشكرك على الرد السريع: +1:
إليكم كيف فعلت كل ذلك من وحدة التحكم الخاصة بي ، آمل أن يساعد هذا شخصًا لا يريد التنفيذ من js ، في الواقع نحن نتصل بـ js ولكن من وحدة التحكم Laravel الخاصة بنا ،
$model = User::all();
if (request()->ajax()) {
return DataTables::make($model)
->addIndexColumn()
->addColumn('handleBarColumn',function(User $userData){
return view('admin.pages.forms.handleBarInfo',compact('userData'));
})
->rawColumns(['handleBarColumn'])
->toJson();
}
$html = $builder->columns([
['title' => '','className' => 'details-control','orderable' => false, 'data' => null,'searchable' => false,'defaultContent' => '','width' => '20px'],
// ['data' => 'DT_RowIndex', 'name' => 'DT_RowIndex', 'title' => '#','orderable' => 'false','searchable' => 'false'],
['data' => 'email', 'name' => 'email', 'title' => 'Email'],
['data' => 'handleBarColumn', 'name' => 'handleBarColumn', 'title' => '','visible' => false,'orderable' => false]
])->parameters([
'dom' => 'Bfrtip',
'paging' => true,
'searching' => true,
'info' => true,
'buttons' => [ 'csv' , 'excel' , 'pdf'],
'order' => [1,'asc'],
'drawCallback' => 'function () {
function format ( d ) {
return d.handleBarColumn;
}
let table = $("#formDataTables").DataTable();
$("#formDataTables tbody").on("click", "td.details-control", function () {
let tr = $(this).closest("tr");
let row = table.row( tr );
if ( row.child.isShown() ) {
row.child.hide();
tr.removeClass("shown");
}
else {
row.child(format(row.data())).show();
tr.addClass("shown");
}
});
}',
]);
الآن أخيرًا داخل ملف الشفرة (وهو في حالتي "admin> Pages> Forms> handleBarInfo.blade.php") يمكنك كتابة أي شرط تريده
{{ $userData->email }}
وهنا ملف الفهرس الخاص بي حيث يتم تقديم جميع جداول البيانات
@extends('admin.layout.app')
@section('content')
<div class="ibox">
<div class="ibox-content">
<div class="row">
<div class="col-md-12">
<div class="table-responsive">
{!! $html->table(['class' => 'table table-striped table-bordered', 'id' => 'formDataTables']) !!}
</div>
</div>
</div>
</div>
</div>
<strong i="12">@endsection</strong>
@section('styles')
<style>
#formDataTables tbody td.details-control {
background-image: url('{{ asset('assets/admin/images/details_open.png') }}');
cursor: pointer;
background-repeat: no-repeat;
background-position: center;
background-origin: content-box;
background-size: cover;
padding: 7px;
}
#formDataTables tbody tr.shown td.details-control {
background-image: url('{{ asset('assets/admin/images/details_close.png') }}');
cursor: pointer;
background-repeat: no-repeat;
background-position: center;
background-origin: content-box;
background-size: cover;
padding: 7px;
}
#formDataTables tbody tr .rowDetails p {
font-size: 14px;
font-weight: 800;
float: left;
margin-right: 10px;
padding: 1px;
margin-bottom: 0;
}
#formDataTables tbody tr .rowDetails a{
}
#formDataTables tbody tr .rowDetails td{
padding: 5px;
}
.m-r-10{
margin-right: 10px !important;
}
</style>
<strong i="13">@endsection</strong>
@section('scripts')
{!! $html->scripts() !!}
<strong i="14">@endsection</strong>
إليكم كيف فعلت كل ذلك من وحدة التحكم الخاصة بي ، آمل أن يساعد هذا شخصًا لا يريد التنفيذ من js ، في الواقع نحن نتصل بـ js ولكن من وحدة التحكم Laravel الخاصة بنا ،
$model = User::all(); if (request()->ajax()) { return DataTables::make($model) ->addIndexColumn() ->addColumn('handleBarColumn',function(User $userData){ return view('admin.pages.forms.handleBarInfo',compact('userData')); }) ->rawColumns(['handleBarColumn']) ->toJson(); } $html = $builder->columns([ ['title' => '','className' => 'details-control','orderable' => false, 'data' => null,'searchable' => false,'defaultContent' => '','width' => '20px'], // ['data' => 'DT_RowIndex', 'name' => 'DT_RowIndex', 'title' => '#','orderable' => 'false','searchable' => 'false'], ['data' => 'email', 'name' => 'email', 'title' => 'Email'], ['data' => 'handleBarColumn', 'name' => 'handleBarColumn', 'title' => '','visible' => false,'orderable' => false] ])->parameters([ 'dom' => 'Bfrtip', 'paging' => true, 'searching' => true, 'info' => true, 'buttons' => [ 'csv' , 'excel' , 'pdf'], 'order' => [1,'asc'], 'drawCallback' => 'function () { function format ( d ) { return d.handleBarColumn; } let table = $("#formDataTables").DataTable(); $("#formDataTables tbody").on("click", "td.details-control", function () { let tr = $(this).closest("tr"); let row = table.row( tr ); if ( row.child.isShown() ) { row.child.hide(); tr.removeClass("shown"); } else { row.child(format(row.data())).show(); tr.addClass("shown"); } }); }', ]);
الآن أخيرًا داخل ملف الشفرة (وهو في حالتي "admin> Pages> Forms> handleBarInfo.blade.php") يمكنك كتابة أي شرط تريده
{{ $userData->email }}
وهنا ملف الفهرس الخاص بي حيث يتم تقديم جميع جداول البيانات
@extends('admin.layout.app') @section('content') <div class="ibox"> <div class="ibox-content"> <div class="row"> <div class="col-md-12"> <div class="table-responsive"> {!! $html->table(['class' => 'table table-striped table-bordered', 'id' => 'formDataTables']) !!} </div> </div> </div> </div> </div> <strong i="13">@endsection</strong> @section('styles') <style> #formDataTables tbody td.details-control { background-image: url('{{ asset('assets/admin/images/details_open.png') }}'); cursor: pointer; background-repeat: no-repeat; background-position: center; background-origin: content-box; background-size: cover; padding: 7px; } #formDataTables tbody tr.shown td.details-control { background-image: url('{{ asset('assets/admin/images/details_close.png') }}'); cursor: pointer; background-repeat: no-repeat; background-position: center; background-origin: content-box; background-size: cover; padding: 7px; } #formDataTables tbody tr .rowDetails p { font-size: 14px; font-weight: 800; float: left; margin-right: 10px; padding: 1px; margin-bottom: 0; } #formDataTables tbody tr .rowDetails a{ } #formDataTables tbody tr .rowDetails td{ padding: 5px; } .m-r-10{ margin-right: 10px !important; } </style> <strong i="14">@endsection</strong> @section('scripts') {!! $html->scripts() !!} <strong i="15">@endsection</strong>
هل يمكننا وضع ajax داخل وحدة تحكم php الخاصة بنا؟ مثلما تفعل ، فأنت تتصل بـ js داخل وحدة التحكم. هل من الممكن إذا وضعنا ajax داخل js على وحدة التحكم؟
أعلم أن هذا قديم ، ولكن فقط لذكر vipertecpro ، فإن
أعتقد أنه يجب عليك استخدام "initComplete" لهذا الغرض.
التعليق الأكثر فائدة
إليكم كيف فعلت كل ذلك من وحدة التحكم الخاصة بي ، آمل أن يساعد هذا شخصًا لا يريد التنفيذ من js ، في الواقع نحن نتصل بـ js ولكن من وحدة التحكم Laravel الخاصة بنا ،
الآن أخيرًا داخل ملف الشفرة (وهو في حالتي "admin> Pages> Forms> handleBarInfo.blade.php") يمكنك كتابة أي شرط تريده
{{ $userData->email }}
وهنا ملف الفهرس الخاص بي حيث يتم تقديم جميع جداول البيانات