> 웹 프론트엔드 > JS 튜토리얼 > jQuery와 PHP를 사용하여 페이지 새로 고침 없이 양식 데이터를 제출하는 방법은 무엇입니까?

jQuery와 PHP를 사용하여 페이지 새로 고침 없이 양식 데이터를 제출하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-12-23 15:17:10
원래의
969명이 탐색했습니다.

How to Submit Form Data Without Page Refresh Using jQuery and PHP?

jQuery 및 PHP(form.php)를 사용하여 Ajax를 통해 양식 데이터 제출

양식 제출 시 브라우저 리디렉션을 방지하려면 jQuery를 활용할 수 있습니다. 그리고 아약스. 제공된 것과 같은 양식에 대해 이를 달성하는 방법은 다음과 같습니다.

<form>
로그인 후 복사

jQuery:

$(document).ready(function () {
    $('#foo').submit(function (event) {
        event.preventDefault();
        var $form = $(this);
        var $inputs = $form.find('input, select, button, textarea');
        var serializedData = $form.serialize();
        $inputs.prop('disabled', true);
        $.ajax({
            url: '/form.php',
            type: 'post',
            data: serializedData,
            done: function (response) {
                console.log('Hooray, it worked!');
            },
            fail: function (jqXHR, textStatus, errorThrown) {
                console.error(
                    'The following error occurred: ' +
                        textStatus,
                    errorThrown
                );
            },
            always: function () {
                $inputs.prop('disabled', false);
            }
        });
    });
});
로그인 후 복사

PHP(form.php):

// Access posted data through $_POST
$bar = isset($_POST['bar']) ? $_POST['bar'] : null;
로그인 후 복사

대신 약어로 .post를 사용할 수도 있습니다. jQuery의 .ajax:

$.post('/form.php', serializedData, function (response) {
    console.log('Response: ' + response);
});
로그인 후 복사

팁:

  • 악성 삽입을 방지하려면 게시된 데이터를 삭제하세요.
  • jQuery 코드를 $(document).ready() 핸들러.
  • 콜백을 연결할 수 있습니다. 더 많은 제어를 위한 핸들러(done(), failure(), Always()).

위 내용은 jQuery와 PHP를 사용하여 페이지 새로 고침 없이 양식 데이터를 제출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿