我制作了Post和User模型并定义了两者之间的一对多关系,如下所示:
user.php的
def iter
post.php中
Any
现在,在我的博客控制器中,我将Post类压缩到我的博客视图中,如下所示:
BlogController.php
<?php
namespace App;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'email', 'password', 'profile_picture',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
public function posts () {
return $this->hasMany(Post::class,'post_author');
}
}
现在我尝试访问博客视图中的关系:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Post extends Model
{
protected $fillable = [
'post_title', 'post_content', 'post_author', 'post_type', 'created_at', 'updated_at',
];
public function user() {
return $this->belongsTo(User::class,'id');
}
public function postfields() {
return $this->hasMany(PostField::class);
}
}
当数据库中只有一篇博文时,博客视图中的所有内容都应该显示,但是当有多个博客文章时,我会收到以下错误:
84794846d554b14eb937f08dfef09b6f1edd91c6.php第43行中的ErrorException: 试图获取非对象的属性(查看:C:\ MAMP \ htdocs \ Biota-New \ resources \ views \ blog.blade.php)
非常感谢任何帮助。
这里是$ blog_posts变量的DD:
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use App\Post;
use App\User;
class BlogController extends Controller
{
public function index(Post $post) {
$blog_posts = Post::with('user')->where('post_type', '=', 'blog')->get();
return view('blog', compact('blog_posts'));
}
}
Blog.blade.php
@foreach ($blog_posts as $blog_post)
<div class="post item">
{{ $blog_post->post_title }}
{{ $blog_post->post_content }}
{{ $blog_post->user->name }}
</div>
@endforeach
答案 0 :(得分:1)
据我所知,Post模型中的User
关系导致异常。所以,当你致电:
{{ $blog_post->user->name }}
找不到与该帖子相关联的用户。我猜测User
表的外键与Laravel的guessed不同:
Eloquent通过检查关系方法的名称并使用_id为方法名称添加后缀来确定默认外键名称。但是,如果Comment模型上的外键不是post_id,则可以将自定义键名作为第二个参数传递给belongsTo方法:
public function post()
{
return $this->belongsTo('App\Post', 'foreign_key');
}
所以在你的情况下,它会是这样的:
public function user()
{
return $this->belongsTo('App\User', 'post_user_id'); //Replace post_user_id with the id convention you are using.
}
的更新强>
感谢你的$ blog_posts上的dd。我可以看到用户正在被提取,但它没有被正确调用。它是一个功能,因此您需要将其视为一个功能。修改刀片文件以检索用户,如下所示:
{{ $blog_post->user()->name }}
这应该获得有效的用户集合。
更新2:
正如我从转储中看到的那样,第二个Post
的用户关系为空。在创建帖子并在刀片中处理它时确保它不为空,将其包装在空检查中:
@foreach ($blog_posts as $blog_post)
<div class="post item">
{{ $blog_post->post_title }}
{{ $blog_post->post_content }}
@if($blog_post->user()!=null)
{{ $blog_post->user()->name }}
@endif
</div>
@endforeach
更新3:
它实际上应该被称为属性而不是函数,因为它在作为函数调用时返回'BelongsTo'。立即尝试以下方法:
@foreach ($blog_posts as $blog_post)
<div class="post item">
{{ $blog_post->post_title }}
{{ $blog_post->post_content }}
@if($blog_post->user!=null)
{{ $blog_post->user->name }}
@endif
</div>
@endforeach
我在这里重现了同样的问题,这解决了它。让我知道它是否适合你。
答案 1 :(得分:0)
我发现没有错误尝试
composer dump-autoload
php artisan view:clear
答案 2 :(得分:0)
试试这个:
而不是
@foreach ($blog_posts as $blog_post)
<div class="post item">
{{ $blog_post->post_title }}
{{ $blog_post->post_content }}
{{ $blog_post->user->name }}
</div>
@endforeach
使用以下内容:
@foreach ($blog_posts as $blog_post)
<div class="post item">
{{ $blog_post->post_title }}
{{ $blog_post->post_content }}
@foreach($blog_post->user as $user)
{{ $user->name }}
@endforeach
@endforeach