dtest84004 2017-06-06 16:38
浏览 193
已采纳

Laravel AJAX控制器和数据返回

I am making an AJAX call from a view:

function compareProducts() {
    var productIds = [];
    $('#compare-widget tbody tr').each(function(i, ele) {
        productIds[i] = $(ele).data('product-id');
    });
    $.ajax({
        url: 'product/compare',
        type: 'POST',
        data: {
            "_token": "{{ csrf_token() }}",
            productIds: productIds
        },
        success: function(result) {
        }
    });
}

which is triggering the controller:

public function compare(Request $request)
{
    $products = Product::whereIn('id', $request->productIds)->get();
    return view('compare', compact('products'));
}

but it is not doing anything in browser directly. When I open chrome inspector I see a OK 200 code, and when I open triggered link there, it shows fine, but I am not able to trigger redirection with AJAX.

If I do a window.location.href = "compare"; I get redirected to right page, but I no longer have access to $products

  • 写回答

2条回答 默认 最新

  • doucuan5365 2017-06-07 04:20
    关注

    You could save the products to the session and redirect to the compare page, that way you would have access to the products when you redirect to the compare page

    public function compare(Request $request)
    {
        $products = Product::whereIn('id', $request->productIds)->get();
    
        session(['products' => $products]);
    
        return url('compare');
    }
    

    and in your success callback you could redirect to the compare page

    success: function (result) {
        window.location.href = result;
    }
    

    and in your compare view access the products from the session

    {{ session('products') }}
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • dongzhun1857 2017-06-06 17:58
    关注

    Ajax data is lost after page refresh. You should use a submit method.

    I suggest you change your implementation to be something like this

    <form id="the-form" method="post" action="/products/compare">
        {{ csrf_field() }}
    </form>
    
    <button id="compare-link">Compare</button>
    
    <script>
       $('#compare-link').click(
            function(){
                $('.hidden-compare').remove();
                let productIds = [5,2,3,4]; // implement your algorithm
                productIds.forEach(function(c) {
                    $('#the-form').append('<input type="hidden"name="compares[]" class="hidden-compare" value="'+c+'">');
                });
                $('#the-form').submit()
              }
        );
    </script>
    
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥100 webapi的部署(标签-服务器)
  • ¥20 怎么加快手机软件内部计时的时间(关键词-日期时间)
  • ¥15 C语言除0问题的检测方法
  • ¥15 为什么四分管的内径有的是16mm有的15mm,四分不应该是12.7mm吗
  • ¥15 macos13下 ios交叉编译的问题
  • ¥15 bgz压缩文件怎么打开
  • ¥15 封装dll(引入了pcl的点云设计库)
  • ¥30 关于#开发语言#的问题:我需要在抄板的基础上再抄板抄程序,根据RDA8851CM基础上开发
  • ¥15 oracle 多个括号,怎么删除指定的括号及里面的内容?
  • ¥15 小新14API2019想用bios调风扇