使用 Laravel 的 Eloquent ORM 获取多态关系、关联关系的 JSON 数据问题

  • 第一次使用Laravel来写API,在这遇到一个问题,有以下几张表feeds、comments、likes,使用Eloquent ORM来获取下面的json,
[
  {
    id:1,
    content:"xxx",
    like_users:[{id:1, account_id:"nicname"}, ] 这里希望获取user对象
    comments:[{id:1, content:"xxx", user:{}, parent_user:{}},]  
  },
]
  • 这是我的PHP代码
$paginator = Feed::with('comments', 'likes', 'images')
                ->orderBy('created_at', 'desc')
                ->paginate($pageSize);
  • 但是获取的json格式为
[
  {
    id:1,
    content:"xxx",
    like_users:[{id:1, account_id:"x", likeable_id:"", likeable_type:"xxx"}, ]//返回的是likes表里的数据
    comments:[{id:1, content:"xxx", user_id:"x", parent_id:"x"},]   
  },
]
  • 求大神指教,下面是我的model层
class Account extends Eloquent {
}
class Feed extends Eloquent {
    public function comments(){
        return $this->hasMany('Comment');
    }
    public function likes() {
        return $this->morphMany('Like', 'likeable');
    }
}
class Comment extends Eloquent {
   public function parent() {
        return $this->belongsTo('Comment');
    }
    public function children() {
        return $this->hasMany('Comment');
    }   
}
class Like extends Eloquent {
   public function likable() {
        return $this->morphTo();
    }
}
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 10
Summer

检查下: likeablelikable

9年前 评论
Summer

有错别字了.

9年前 评论
Summer

另外, API 接口数据返回的话, 建议使用 https://github.com/thephpleague/fractal 来做

9年前 评论
Summer

@yangyugang 不客气. :sunglasses: 一边写安卓还一边写自己写接口吗?

9年前 评论
Summer

@yangyugang Laravel 是个好选择, Lucky guess. :smile:

9年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!