[英]Eager Loading Relationships with Yajra Laravel Error
大家好,我要做的第一件事是将房间表所附的酒店表中的数据显示到单个列表页面。
我收到此错误
异常消息:对未定义方法App \\ Hotel :: map()的调用
RoomController.php
public function apiRoom() {
$hotels = Room::with('hotel');
return Datatables::eloquent($hotels)
->addColumn('hotel', function (Room $htl) {
return $htl->hotel->map(function ($hotellist) {
return str_limit($hotellist->hotel_name);
});
});
$rooms = Room::all();
return Datatables::of($rooms)
->addColumn('action', function ($rooms) {
return '<a onclick="editForm('.$rooms->id.')" data-toggle="tooltip" data-original-title="Edit"> <i class="fa fa-pencil text-inverse m-r-10"></i> </a>'.
'<a onclick="deleteData('.$rooms->id.')" data-toggle="tooltip" data-original-title="Close"> <i class="fa fa-close text-danger"></i> </a>';
})->make(true);
房间list.blade.php
var table = $('#room-table').DataTable({
processing: true,
serverSide: true,
ajax: "{{ route('api.room') }}",
columns: [
{data: 'id', name: 'id'},
{data: 'hotel', name: 'hotel.hotel_name'},
{data: 'room_name', name: 'room_name'},
{data: 'bonus_sum', name: 'bonus_sum'},
{data: 'action', name: 'action', orderable: false, searchable: false}
]
});
模型文件Room.php
class Room extends Model {
protected $primaryKey = 'id';
protected $fillable = ['hotel_id', 'room_name', 'bonus_sum'];
public function Hotel() {
return $this->belongsTo('App\Hotel', 'hotel_id');
}
}
Room
仅属于一间Hotel
。 因此, $htl->hotel
是单个对象,而不是集合,并且您不能在其上调用map()
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.