合并三个不相关的表并在单个页面上显示结果



我在 laravel5.6 vuejs2 应用程序中有三个表

  1. 源(ID、消息、created_at、updated_at、created_by、updated_by(
  2. 分类广告(ID、category_id、标题、描述、关键字、created_at、updated_at、created_by updated_by(
  3. 新闻(ID、标题、副标题、内容、关键字、created_at、created_by、updated_at、updated_by(。

我想创建一个像Facebook这样的后端,我可以将所有最新帖子列为故事。在这种情况下,我想发布带有加载更多按钮的提要、分类广告和新闻。如何实现这一点?

$feed = Feed::latest()->paginate(10);
$classifieds = Classifieds::latest()->paginate(10);
$news = News::latest()->paginate(10);
$stories = array_merge(['feed', 'classifieds', 'news']);

这是行不通的,我知道这不是正确的方法。我是 laravel 的学习者,在这方面没有找到太多帮助。

谁能告诉我如何做到这一点,以便我可以将仪表板页面上不相关的所有三个表列为最新故事。

创建模型集合是很酷的方法。

$collection = new ModelCollection();
$feed = Feed::latest();
$classifieds = Classifieds::latest();
$news = News::latest();
$stories = $collection->merge($feed)->merge($classifieds)->merge($news);

编辑: 你可以做这样的分页操作。

$page = $request->get('page');
$page = $page ?: (Paginator::resolveCurrentPage() ?: 1);
$collection = new ModelCollection();
$feed = Feed::latest();
$classifieds = Classifieds::latest();
$news = News::latest();
$stories = $collection->merge($feed)->merge($classifieds)->merge($news);
$items = new LengthAwarePaginator($stories->forPage($page, 30), $result->count(), 30, $page,['path' => '/search']);

LengthAwarePaginator 可以做到这一点,用法是

LengthAwarePaginator(currentPageItems, collection_count, perPage, currentPage)

我希望这是有帮助的。编辑部分不起作用,我只是告诉它,因为 lengthawarepaginator 可以给你一个想法。

最新更新