laravel - Laravel 5.7 多对多关系问题与分页
问题描述
我对 laravel 中的这种关系有一些问题。 这是我的 mysql 表
这是我的控制器代码:
namespace App\Http\Controllers\Dynamic;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Blogs;
use LaravelLocalization;
use App\BlogsCategory;
class BlogsController extends Controller
{
public function main(){
//$posts = new Blogs::where('lang',LaravelLocalization::getCurrent);
$posts = new Blogs;
$data = $posts::where('lang',LaravelLocalization::getCurrentLocale())->where('created_at','<=',NOW())->orderBy('created_at','DESC')->paginate(config('PAGINATOR_COUNTER'));
return view('Dynamics.Blogs.Main',compact('data'));
}
}
这是我的博客模型:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
use App\BlogsCategory;
class Blogs extends Model
{
public function categories()
{
return $this->belongsToMany(BlogsCategory::class);
}
}
和 BlogsCategory 模型:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
use App\Blogs;
class BlogsCategory extends Model
{
public function blogs_data()
{
return $this->belongsToMany(Blogs::class);
}
}
我想获取所有博客帖子,他们的 lang col 是 'fa' 和他们的类别并在我的视图中显示。这是我的视图代码:
@forelse($data as $tmp)
<div class="blog-item-left">
<div class="blog-left-img">
<img src="/upload/blogs/small/{{$tmp->img}}" alt="{{$tmp->title}}" />
</div>
<div class="blog-left-text">
<div class="blog-text">
<span><i class="fas fa-box"></i>
@foreach($data->categories as $cat_data)
{{$cat_data->title}}
@endforeach
</span>
<a href="#"><h4 class="title">{{$tmp->title}}</h4></a>
<p>{{$tmp->description}}</p>
</div>
</div>
</div>
@empty
<h2>No Data to show!</h2>
@endforelse
这段代码告诉我这个错误:
未定义属性:Illuminate\Pagination\LengthAwarePaginator::$categories(查看:/Users/soroush/Sites/msadd/resources/views/Dynamics/Blogs/Main.blade.php)
我必须做什么?
解决方案
您只想使用查询加载“类别”关系。
class BlogsController extends Controller
{
public function main(){
//$posts = new Blogs::where('lang',LaravelLocalization::getCurrent);
$data = Blogs::with('categories')
->where('lang',LaravelLocalization::getCurrentLocale())
->where('created_at','<=', now())
->orderBy('created_at','DESC')
->paginate(config('PAGINATOR_COUNTER'));
return view('Dynamics.Blogs.Main',compact('data'));
}
}
并像这样更改您的刀片(视图)模板“类别”迭代:
@foreach($tmp->categories as $cat_data)
{{$cat_data->title}}
@endforeach
推荐阅读
- r - R-在日期字段上创建一个新字段应用条件
- c# - awaitng 异步事件处理程序不等待方法继续
- ios - 核心数据,关系 - 将多个选定的行存储到实体
- c++ - 使用#define 声明函数
- asp.net-core-mvc - 文化不一致 - 剃刀视图和视图模型之间的模型绑定中忽略了小数点分隔符
- firebase - @firebase/数据库警告
- javascript - Javascript Google Cloud Function 尝试在 FirebaseDatabase 中获得新的附加值
- docker - 构建 docker 容器时超出最大深度消息
- validation - 如果返回 false,Cakephp 3 更新验证提供程序中的值
- ios - 如何在 App Store Connect 中批准新版本