gpt4 book ai didi

php - 尝试在 null 上读取属性 "name"

转载 作者:行者123 更新时间:2023-12-04 12:34:28 26 4
gpt4 key购买 nike

类别模型

class Category extends Model
{
use HasFactory;

protected $fillable= ['name','number'];

public function news(){

return $this->hasMany(News::class);
}
新闻模式
class News extends Model
{
use HasFactory;

protected $fillable= ['cat_id','title','photo','description','author_id','status'];

public function category(){
return $this->belongsTo(Category::class);
}

public function author(){
return $this->belongsTo(Author::class);
}
作者模型
class Author extends Model
{
use HasFactory;

protected $fillable= ['name','status'];

public function news(){
return $this->hasMany(News::class);
}
3个模型之间存在关系。我想在 news-list.blade.php 中显示类别名称而不是 category_id .我收到此错误。
这是我的 Controller 功能
  public function news_index(){
$news= News::with('category')->get();
return view('News.list',compact('news'));
}
这是我的 Blade 页面。当我输入 $new->category->name 时出现错误而不是 cat_id .
@foreach($news as $new)
<tr>
<th scope="row">{{$loop->iteration}}</th>
<td> {{$new->category->name}}</td>
<td> {{$new->title}}</td>
<td> @if($new->photo)
<a href="{{url('storage/images/'.$new->photo)}}" target="_blank" class="btn btn-sm btn-secondary">Görüntüle</a></td>
@endif
</td>
<td> {{$new->author_id}}</td>
<td> {{$new->description}}</td>
<td> {{$new->status}}</td>

<td>
<a class="btn btn-danger" onclick="return confirm('Silmek istediğinize emin
misiniz?')" href="{{route('news_delete', $new->id)}}"><i class="fa fa-trash"></i></a>
<a class="btn btn-primary" href="{{route('news_update',$new->id)}}"><i class="fa
fa-pen"></i></a>

</td>
</tr>
@endforeach

这是我的新闻迁移表
public function up()
{
Schema::create('news', function (Blueprint $table) {
$table->id();
$table->unsignedBigInteger('cat_id');
$table->string('title');
$table->string('photo');
$table->longText('description');
$table->unsignedBigInteger('author_id');
$table->boolean('status')->default('1');
$table->foreign('cat_id')->references('id')->on('categories')->onDelete('cascade');
$table->foreign('author_id')->references('id')->on('authors')->onDelete('cascade');
$table->timestamps();
});
}

最佳答案

您需要在定义类别关系时明确定义类别外键。因为你的类别外键不是 category_id;它是 cat_id。
例如,您需要在 News 模型中定义类别关系,如下所示:

public function category()
{
return $this->belongsTo(Category::class, 'cat_id');
}

关于php - 尝试在 null 上读取属性 "name",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66185760/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com