$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(
您可以使用表单将数据发送回服务器
更新从get
到post
的路线
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');