dow98764 2015-10-29 03:52
浏览 718

排除Laravel会从模型结果中追加值

Laravel has the option to add an $appends array to each model making additional values automatically available as if they are database attributes by adding accessors for each.

This is normally pretty handy, except in this case I need to ONLY get the fields I put into select() because DataTables is expecting only what I send to it.

Example:

Item::select(['image', 'name', 'color']);

Will return appended fields after color in the attributes.

How do I force the exclusion of the appends values when returning results?

Or alternatively, how do I get DataTables to ignore certain attributes?

Not sure which is the least time costly route.

Currently using yajra/laravel-datatables package to send data to the jQuery DataTables AJAX request.

  • 写回答

2条回答 默认 最新

  • duanlu0386 2015-10-29 06:19
    关注

    You can call each function in the collection object and then use setHidden method to exclude the unwanted fields like this

    $item= Item::select(['image', 'name', 'color'])->get()->each(function($row){
                        $row->setHidden(['appendedField1', 'appendedField2']);
                    });
    

    And for the yajra/laravel-datatables you can use something like

    $item= Item::select(['image', 'name', 'color']);
    return Datatables::of($item)->remove_column('appendedField1');
    
    评论

报告相同问题?

悬赏问题

  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法