首页 > 解决方案 > 显示使用 laravel 8 从数据库中获取的下拉列表中的数据

问题描述

我必须在产品表单的下拉列表中显示类别值,给定的代码来自我的视图,错误是未定义的 $categories。这是我在 laravel 中的第一个代码我不知道如何在其他文件中进行更改。使用了哪个变量在 foreach 中?或者我必须在 ProductController 中创建新功能?

<form action="/upload_product" method="post">
    @csrf
    <label>Choose Categories</label>
    <select name="category_id" id="category" class="category">
        <option disable selected>--select category--</option>
        @foreach($categories as $item)
        <option value="{{ $item->id }}">{{ $item->name}}</option>
    @endforeach
    </select>
        <input type="text" name="name" placeholder="name">
        <input type="number" name="sale_price" placeholder="sale_price">
   </form>

模型产品.php

        class Product extends Model
           {
     use HasFactory; 
     protected $table = 'products';
     public $timestamps = true;

    public function category(){
    return $this->belongsTo('App\Models\Category');
} 

} 模型类别.php

   class Category extends Model
  {
    use HasFactory;
    public $fillable = [ 'name' ];
    protected $dates = [ 'deleted_at' ];
    public $timestamps = true;

    public function products (){
    return $this->hasMany('App\Models\Product');
  }
}

产品控制器.php

   <?php
 namespace App\Http\Controllers; 
 use App\Models\Product;
 use App\Models\Category;
 use Illuminate\Http\Request;

class ProductController extends Controller
{ 
  public function index()
{
    $products = Product::all(); 
    return view('products/index', ['products'=>$products]);
}
 public function view()
{
  $products = Product::with('category')->get(); 
  $categories = Category::with('products')->get();
  return view ('product.view')-> with([
    'products' => $products,
    'categories' => $categories,
]);
}

标签: laraveldrop-down-menu

解决方案


$categories的索引文件中没有。根据该index方法,您只是发送产品:

public function index()
{
    $products = Product::all(); 
    return view('products/index', ['products'=>$products]);
}

所以也添加类别。


推荐阅读