分析来自Laravel中关系模型的数据

时间:2018-04-20 13:55:55

标签: php laravel pagination laravel-5.6

如果标题不完全有意义,请道歉......我不确定模型链接的确切术语是否是控制器中的相关数据。

我正在尝试使用用户创建的帖子对表格进行分页。

我之前设法对它进行了分页,而在posts表中没有user_id。但我已将user_id添加到posts表中,并运行可正常运行的迁移。

以下是我的Post模型:         

    namespace App;

    use Illuminate\Database\Eloquent\Model;

    class Post extends Model
    {
      public function user(){
        return $this->belongsTo('App\User');
      }
    }

这是我的User模型:         

    namespace App;

    use Illuminate\Notifications\Notifiable;
    use Illuminate\Foundation\Auth\User as Authenticatable;

    class User extends Authenticatable
    {
        use Notifiable;
        protected $fillable = ['name', 'email', 'password',];

        protected $hidden = ['password', 'remember_token',];

        public function posts() {
          return $this->hasMany('App\Post');
        }
    }

这是帖子控制器的相关部分:         

    namespace App\Http\Controllers;

    use Illuminate\Http\Request;
    use App\Post;
    use App\User;
    use Session;
    use Carbon\Carbon;

    class PostController extends Controller
    {

      public function index()
      {

        $user_id = auth()->user()->id;
        $user = User::find($user_id);

        return view('posts.index')->with('posts', $user->posts);
      }

我认为只会将->paginate(5)附加到$user中的PostController,但这似乎不起作用。

我得到以下内容:

Undefined property: Illuminate\Pagination\LengthAwarePaginator::$posts

我尝试在{!! $posts->links() !!}之前的posts.index视图中加入@foreach,但这样做了:

Undefined property: Illuminate\Pagination\LengthAwarePaginator::$posts

我正在尝试通过创建这个crud应用程序来学习Laravel基础知识,并尝试将两个教程组合在一起,但我显然遗漏了一些东西。

1 个答案:

答案 0 :(得分:4)

你可以像这样调用->paginate()这样的关系(我也删除了不必要的用户查询,因为auth()->user()已经执行了它):

public function index()
{
    $user = auth()->user();
    $posts = $user->posts()->paginate();
    // Or with 1 line: $posts = auth()->user()->posts()->paginate();
    return view('posts.index')->with('posts', $posts);
}