Как отправить запрос формы, используя ajax без ссылки на страницу sh и вернуть сообщение в laravel? - PullRequest
1 голос
/ 07 апреля 2020

Я пытаюсь отправить запрос формы и сохранить данные без ссылки на страницу sh или перенаправления. И отправьте сообщение об успехе на

 @if (session('message'))
    <div class="alert alert-success">
       {{ session('message') }}
    </div>
   @endif

, я получу белую страницу после нажатия кнопки Отправить со следующим ответом

{
"msg": "Setting created successfully"
}

Форма html:

<form method="POST" action="/mail/store" id="contactForm">
    @csrf
    <div style="display: flex;" class="name-email">
        <div class="form-group col-sm-6 fl_wrap">

            <input type="text" name="name" value="{{ old('name') }}" id="name"
                   class="form-control fl_input" placeholder="Name"
                   required>
        </div>
        <div class="form-group col-sm-6 fl_wrap">

            <input type="text" name="email" value="{{ old('email') }}" id="email"
                   placeholder="Email"
                   class="form-control fl_input" required>
        </div>
    </div>
    <div class="form-group col-sm-12 fl_wrap mt-2">
    <textarea type="text" name="message" rows="7" value="{{ old('message') }}" id="message"
              class="form-control fl_input" placeholder="message"
              required></textarea>
    </div>
    <div class="form-group text-center mt-5">
        <button type="submit" value="save" id="submit" class="btn btn-warning submit"
                style="color: white;background: rgb(59, 199, 246); border-color: rgb(59, 199, 246); width: 140px;">
            send
        </button>
    </div>

</form>

Js Код: Я думаю, что-то не так или отсутствует в коде ajax, но я не знаю, где

 <script src="/js/jquery.min.js"></script>
     <script !src="" type="text/javascript">
         $(document).ready(function () {
             $.ajaxSetup({
                    headers: {
                           'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
                        }
            });
$('#contactForm').on('submit',function (e) {
                        e.preventDefault();

                        var name = $('#name').val();
                        var email = $('#email').val();
                        var message = $('#message').val();

                        $.ajax({
                           type: "POST",
                           url: host+'/mail/store',
                            data: { name:name ,email:email,message:message},
                            success: function( msg ) {
                                $("body").append("<div>"+msg+"</div>");
                            }
                        });

                        $.post('contactForm', { name:name, email:email, message:message }, function () {
                            console.log(data);
                            $('#postRequestData').html(data);
                        });
                    });
                });

хранить функцию в контроллере

 public function store(Request $request)
    {

        $mail = new Mail();
        $mail->name = $request->name;
        $mail->mail = $request->email;
        $mail->message = $request->message;
        $mail->save();

        $result = array(
            'msg' => 'Setting created successfully' );
        return Response::json($result);
    }

Маршруты

Route::get('/mail','MailsController@create');

Route::post('/mail/store','MailsController@store');

1 Ответ

2 голосов
/ 07 апреля 2020

Попробуйте это:

$.post("{{ url('mail/store') }}", {
    name, email, message, '_token': "{{ csrf_token() }}"
}, function(data) {
    $('#postRequestData').html(data.message);
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...