我正在使用Laravel开发一个简单的购票应用程序。
用户选择要购买的票证后,我在更新视图时遇到麻烦,无论我在ajaxRequestPost中使用哪种重定向类型,该视图仍然停留在 / 重定向到付款/ {id} 。
但是,我确实得到了文件 payments.index 的返回,但是视图没有更新为返回的内容。
BitBucket代码:https://bitbucket.org/naimrahidin/laravel_ticketing/src/master/
routes / web.php
Route::resource('/', 'TicketController');
Route::post('createOrder', 'OrderController@ajaxRequestPost');
Route::get('/payments/{id}', 'PaymentController@show');
TicketController.php
public function index(){
$tickets = Ticket::all();
return view('tickets.index', compact('tickets'));
}
OrderController.php
public function ajaxRequestPost(Request $request)
{
$input = $request->all();
for($i = 1; $i < 4; $i++){
if($input['ticket_'.$i.'_q'] != 0) {
$spkAdmin = new Order();
$spkAdmin->ticket_id = $i;
$spkAdmin->quantity = (int)$input['ticket_'.$i.'_q'];
$spkAdmin->total = (int)$input['ticket_'.$i.'_t'];
$spkAdmin->user_id = $input['user_id'];
$spkAdmin->save();
$orders = array(
'id' => $i,
'quantity' => (int)$input['ticket_'.$i.'_q'],
'total' => (int)$input['ticket_'.$i.'_t']
);
}
}
return redirect()->action(
'PaymentController@show', ['id' => $input['user_id']]
);
}
PaymentController.php
public function show($id)
{
$orders = DB::table('orders')->where('user_id', $id)->get();
return view('payments.index', ['orders' => $orders]);
}
payments / index.blade.php
@extends('base')
@section('main')
<div class="row">
<div class="col-sm-12">
<h1 class="display-3">Payments</h1>
<h3 class="display-5" data-user-id="1">Naim Rahidin</h3>
<table class="table table-striped">
<thead>
<tr>
<td>Ticket ID</td>
<td>Quantity</td>
<td>Total</td>
</tr>
</thead>
<tbody>
@foreach($orders as $order)
<tr>
<td>{{$order->ticket_id}}</td>
<td>{{$order->quantity}}</td>
<td>{{$order->total}}</td>
</tr>
@endforeach
</tbody>
</table>
<div class="order_detail">
<p>Total: RM <span id=grand_total>0</span></p>
<p id="proceed" class="btn btn-primary">Checkout</p>
</div>
</div>
</div>
@endsection
答案 0 :(得分:0)
嗨,我认为$input['user_id']
的ID不是int,而是strint,请转换为int
使用type casting
例如使用(int)
变量的开头并尝试使用此代码
return redirect()->action(
'PaymentController@show', ['id' => (int)$input['user_id']]
);
checkout.js文件
$.ajax({
type: 'POST',
url: '/createOrder',
data: {
ticket_1_q: ticket_1_q,
ticket_2_q: ticket_2_q,
ticket_3_q: ticket_3_q,
ticket_1_t: ticket_1_t,
ticket_2_t: ticket_2_t,
ticket_3_t: ticket_3_t,
user_id: 1
},
dataType: 'json',
success: function(data) {
if (data.status == 200) {
window.location.href = data.data;
}
},
error: function(xhr, ajaxOptions, thrownError){
alert(thrownError);
},
});
控制器命令
public function ajaxRequestPost(Request $request)
{
$input = $request->all();
for($i = 1; $i < 4; $i++){
if($input['ticket_'.$i.'_q'] != 0) {
$spkAdmin = new Order();
$spkAdmin->ticket_id = $i;
$spkAdmin->quantity = (int)$input['ticket_'.$i.'_q'];
$spkAdmin->total = (int)$input['ticket_'.$i.'_t'];
$spkAdmin->user_id = $input['user_id'];
$spkAdmin->save();
$orders = array(
'id' => $i,
'quantity' => (int)$input['ticket_'.$i.'_q'],
'total' => (int)$input['ticket_'.$i.'_t']
);
}
}
$url = "/payments/".$input['user_id'];
return response()->json([
'status'=>200,
'message'=>"done",
'data'=> $url
]);
}
答案 1 :(得分:0)
找出答案。
因为我通过Ajax调用createOrder,所以OrderController应该将呈现的视图作为响应发送,并且在ajax.success处应该替换html。
已添加到OrderController.php
$html = view('payments.index')->render();
$response = response()->json(['success' => true, 'html' => $html]);
return $response;
ajax
success: function(data) {
$('.container').html(data.html);
}