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

分享 yangyugang ⋅ 于 3年前 ⋅ 最后回复由 session 3年前 ⋅ 8146 阅读
  • 第一次使用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();
    }
}
成为第一个点赞的人吧 :bowtie:
回复数量: 10
暂无评论~~
  • 请注意单词拼写,以及中英文排版,参考此页
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`, 更多语法请见这里 Markdown 语法
  • 支持表情,使用方法请见 Emoji 自动补全来咯,可用的 Emoji 请见 :metal: :point_right: Emoji 列表 :star: :sparkles:
  • 上传图片, 支持拖拽和剪切板黏贴上传, 格式限制 - jpg, png, gif
  • 发布框支持本地存储功能,会在内容变更时保存,「提交」按钮点击时清空
  请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!
Ctrl+Enter