Laravel 5:如何显示消息并在 Ajax post 后重定向

Laravel 5: How do I display a message and redirect after an Ajax post

我有一个简单的博客 post 页面,它通过 ajax jquery 提交数据。 它工作正常,但目前,它 returns 提交后的 json 响应。

我需要它做的是在提交页面上向用户显示成功消息,然后将他重定向到主要文章页面。

如果我注释掉 return Response::json($response); 我得到一个空白页面,但我不想自动将他重定向到另一个视图,我想给他显示一条消息 5 秒钟,然后再重定向他。

而且 $("#ajaxResponse").append(msg); 什么也没做。

这是我的控制器

public function store(Requests\ArticleRequest $request)
    {

        $article = new Article($request->all());
        Auth::user()->articles()->save($article);

        $response = array(
            'status' => 'success',
            'msg' => 'Setting created successfully',
        );

        return \Response::json($response);
    }

这是AJAX请求

$(document).ready(function() {
    $('#submit').on('submit', function (e) {
        e.preventDefault();
        var title = $('#title').val();
        var body = $('#body').val();
        var published_at = $('#published_at').val();
        $.ajax({
            type: "POST",
            url: host + '/articles/create',
            data: {title: title, body: body, published_at: published_at},
            success: function( msg ) {
                $("#ajaxResponse").append(msg);
            }
        });
    });
});

这就是风景

<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">

<h1>Write a New Article</h1>

<hr>

{!! Form::open(['url' => 'articles']) !!}
    <p>
        {!! Form::label('title', 'Title:') !!}
        {!! Form::text('title') !!}
    </p>

    <p>
        {!! Form::label('body', 'Body:') !!}
        {!! Form::textarea('body') !!}
    </p>

    <p>
        {!! Form::label('published_at', 'Date:') !!}
        {!! Form::input('date', 'published_at', date('Y-m-d'), ['class' => 'form-control']) !!}
    </p>

    <p>
        {!! Form::submit('Submit Article', ['id' => 'submit']) !!}
    </p>
{!! Form::close() !!}

<h3 id="ajaxResponse"></h3>

@if($errors->any())
    <ul>
    @foreach($errors->all() as $error)
        <li>{{ $error }}</li>
    @endforeach
    </ul>
@endif

<script src="//code.jquery.com/jquery-1.11.0.min.js"></script>
<script src="{{ URL::asset('assets/js/ArticleCreate.js') }}"></script>

您需要在从服务器收到响应后设置超时。试试这个并根据需要进行调整。请参阅下面的示例。

return \Response::json($response);

在你的 js 中

$(document).ready(function() {
  $('#submit').on('submit', function (e) {
    e.preventDefault();
    var title = $('#title').val();
    var body = $('#body').val();
    var published_at = $('#published_at').val();
    $.ajax({
        type: "POST",
        url: host + '/articles/create',
        data: {title: title, body: body, published_at: published_at},
        success: function( data) {
            console.log(data);
            if(data.status == 'success') {
              alert(data.msg);
               setInterval(function () {
                alert("Hello");
               }, 3000);

            }else{
                alert('error');
                console.log(msg);
            }
        }
    });
  });
});

根据需要进行调整以适应您的代码。

js fiddle example

$(document).ready(function () {
  $('.alert-me').click(function () {
    setInterval(function () {
        alert("Hello");
    }, 3000);
  });

});