如何将集合或数组从刀片文件传递到laravel中的控制器



$cartItems包含数据库中的所有产品行,我在刀片文件中使用它。

我想把这个$cartItems从这个刀片文件传回到控制器

注意:$cartItems来自控制器中的index()函数,如下所示。

$cartItems = DB::table('products')->whereIn('id', $cartItemsArray)->get();
return view('cart.index', compact('cartItems')

下面是我的代码。

index.blade.php

<a href="{{route('cart.checkout',$cartItems)}}" class="site-btn">Proceed to checkout</a>

web.php

Route::get('/cart/checkout/{cartItems}', 'CartController@checkout')->name('cart.checkout')->middleware('auth');

CartController.php

public function checkout($cartItems)
{
   dd($cartItems);
   return view('cart.checkout');
}

我得到的错误是,

缺少[Route:cart.checkout][URI:cart/checkout/{cartItems}]所需的参数。(视图:E:\github\LARAVEL\Deal Ocean\resources\views\cart\index.blade.php(

您可以使用表单将数据发送回服务器

更新从getpost 的路线

Route::post('/cart/checkout', 'CartController@checkout')->name('cart.checkout')->middleware('auth');

使用表单将数据发布到服务器。您还可以将任何其他数据与请求一起传递。

<form method="post" action="/cart/checkout">
@foreach($cartItems as $item)
    <input name="cartItems[]" value="{{ $item->id }}"
@endforeach
<button class="site-btn">Proceed to checkout</button>
</form>

在您的控制器中使用Request访问数据

public function checkout(Request $request)
{
    $cartItems = DB::table('products')->whereIn('id', $request->get($cartItems))->get();
   dd($cartItems);
   return view('cart.checkout');
}

如果你想继续获取请求,你应该能够按照

由于$cartItems是产品的集合。因此,您可以发送产品ID,并使用请求中的ID查询产品。

<a href="{{ route('cart.checkout', ['cartItems' => $cartItems->pluck('id')->toArray()]) }}" 
    class="site-btn">Proceed to checkout</a>

更新控制器

public function checkout(Request $request)
{
    $cartItems = DB::table('products')->whereIn('id', $request->get($cartItems))->get();
   dd($cartItems);
   return view('cart.checkout');
}

为什么在CartController。

结账方法如下所示:

   $cartItems = DB::table('products')->whereIn('id', $cartItemsArray)->get();
   return view('cart.checkout', compact('cartItems');

相关内容

  • 没有找到相关文章

最新更新