重定向后视图未更新

时间:2019-06-24 03:42:52

标签: php laravel-5

我正在使用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

2 个答案:

答案 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);
}