> 웹 프론트엔드 > 프런트엔드 Q&A > jquery ajax 양식 제출로 페이지가 새로 고쳐지지 않습니다.

jquery ajax 양식 제출로 페이지가 새로 고쳐지지 않습니다.

WBOY
풀어 주다: 2023-05-18 20:19:06
원래의
1191명이 탐색했습니다.

웹 개발에서 양식 제출은 매우 일반적인 작업이며 일반적으로 양식 제출은 페이지 새로 고침을 통해 완료됩니다. 하지만 양식을 제출한 후 페이지를 새로 고치고 싶지 않다면 어떻게 해야 할까요? 이 기사에서는 jQuery와 Ajax를 사용하여 페이지를 새로 고치지 않고 양식 제출을 구현하는 방법을 소개합니다.

1. 페이지를 새로 고치는 것이 어떨까요

기존 양식 제출 프로세스에서 사용자는 페이지가 새로 고쳐질 때까지 참을성 있게 기다려야 하므로 사용자 경험이 매우 번거롭습니다. 페이지가 새로 고쳐지면 사용자는 이전에 채워진 양식 콘텐츠를 다시 입력해야 할 수 있으며 이로 인해 사용자가 만족하지 못할 수 있습니다. 또한 페이지 새로 고침으로 인해 일부 데이터가 손실되어 사용자에게 불필요한 문제를 일으킬 수도 있습니다.

따라서 Ajax를 통해 페이지를 새로 고치지 않고 양식 제출을 구현하면 사용자 경험을 효과적으로 개선하고 사용자의 시간과 에너지를 절약할 수 있습니다.

2. 구현 단계

다음으로, 다음 단계를 사용하여 페이지를 새로 고치지 않고 양식 제출을 구현하겠습니다.

  1. 양식 제출 이벤트 듣기

먼저 JavaScript를 통해 양식을 제출할 수 있도록 양식의 제출 이벤트에 대한 리스너 함수를 바인딩해야 합니다. 동시에 false를 반환하여 브라우저의 기본 양식 제출 동작을 방지해야 합니다. 코드는 다음과 같습니다.

$('form').submit(function() { 
  // ajax 表单提交代码... 
  return false; 
}); 
로그인 후 복사
  1. Get form data

다음으로 jQuery의 serialize() 메서드를 통해 양식 데이터를 가져와야 합니다. 이 메소드는 후속 Ajax 요청에 사용할 수 있도록 양식의 모든 데이터를 문자열로 직렬화합니다. 코드는 다음과 같습니다.

var formData = $('form').serialize(); 
로그인 후 복사
  1. Ajax 요청 보내기

이제 페이지를 새로 고치지 않고 양식을 제출하려면 jQuery의 ajax() 메서드를 통해 비동기 요청을 보내야 합니다. 코드는 다음과 같습니다.

$.ajax({ 
  type: 'POST', 
  url: 'submit.php', 
  data: formData, 
  success: function(result) { 
    // 处理返回的数据 
  } 
}); 
로그인 후 복사

이 ajax() 메소드에서는 다음 매개변수를 정의합니다.

  • type: 요청 유형입니다. 이 예에서는 POST 방법을 선택했습니다. type:请求的类型。在此例中,我们选择了 POST 方法。
  • url:请求的目标 URL。这里是 submit.php,代表表单提交后将数据发送到该 PHP 文件中。
  • data:发送给服务器的数据。我们使用了之前获取的表单数据 formData。
  • success
  • url: 요청의 대상 URL입니다. 여기에는 양식이 제출된 후 데이터를 보낼 PHP 파일을 나타내는 submit.php가 있습니다.
    data: 서버로 전송된 데이터입니다. 이전에 얻은 폼 데이터인 formData를 사용했습니다.
  1. success: 요청 성공 후 콜백 함수입니다. 이 함수에서는 서버에서 반환한 데이터를 그에 따라 처리할 수 있습니다.

서버가 반환한 데이터를 처리합니다

  • 서버가 데이터를 반환하면 성공 콜백 함수에서 처리할 수 있습니다. 예를 들어 서버에서 반환한 데이터를 페이지에 표시하거나 JavaScript를 통해 페이지 상태를 변경할 수 있습니다. 코드는 다음과 같습니다.
  • success: function(result) { 
      // 处理返回的数据: 
      alert(result); 
      $('form')[0].reset(); 
    } 
    로그인 후 복사
  • 이 콜백 함수에서는 서버가 반환한 데이터에 대해 두 가지 작업을 수행합니다.

JavaScript의 Alert() 메서드를 사용하여 프롬프트 상자를 표시합니다. 그 내용은 서버가 반환한 데이터입니다. 서버.

사용자가 새 데이터를 채울 수 있도록 jQuery의 재설정() 메서드를 통해 양식을 재설정하세요.

이 시점에서 위의 4단계를 통해 페이지를 새로 고치지 않고 양식 제출을 성공적으로 구현했습니다.
  1. 3. 주의사항
Ajax를 통한 양식 제출은 사용자 경험을 크게 향상시킬 수 있지만 사용 중에 주의해야 할 사항도 있습니다.

    양식의 반복 제출 방지
Ajax 요청은 다음과 같습니다. 비동기식이므로 사용자가 제출 버튼을 자주 클릭하면 양식이 반복적으로 제출될 수 있습니다. 이 문제를 방지하려면 Ajax 요청을 보내는 동안 양식의 제출 버튼을 비활성화하고 요청이 완료된 후에 활성화할 수 있습니다. 코드는 다음과 같습니다.

$('form').submit(function() { 
  // 禁用按钮 
  $('input[type="submit"]', this).attr('disabled', 'disabled'); 

  // ajax 表单提交代码... 

  // 启用按钮 
  $('input[type="submit"]', this).removeAttr('disabled'); 
}); 
로그인 후 복사

서버에서 반환된 오류 처리

Ajax 요청에서 서버가 잘못된 상태 코드를 반환하는 경우 이러한 오류를 적시에 처리해야 합니다. 일반적으로 성공 콜백 함수의 데이터를 통해 서버에서 반환된 상태를 판단하고 특정 상황에 따라 후속 처리를 수행할 수 있습니다. 예를 들어, 서버에서 반환된 상태 코드가 401이면 사용자가 로그인되어 있지 않다는 의미일 수 있습니다. 이 경우 계속 접속하려면 페이지 점프를 통해 사용자로 로그인해야 합니다. 🎜
success: function(result) { 
  if (result.status === 'success') { 
    alert('提交成功'); 
    $('form')[0].reset(); 
  } else if (result.status === 'failed') { 
    alert('提交失败'); 
  } else if (result.status === 'error') { 
    alert('发生了错误:' + result.message); 
  } 
} 
로그인 후 복사
🎜4. 요약 🎜🎜이 글에서는 jQuery와 Ajax를 사용하여 페이지를 새로 고치지 않고 양식 제출을 구현하는 방법을 소개합니다. 양식 제출 이벤트를 수신하고, 양식 데이터를 얻고, Ajax 요청을 보내고, 서버에서 반환된 데이터를 처리함으로써 페이지를 새로 고치지 않고도 양식 제출을 구현할 수 있으며 사용자 경험을 크게 향상시킬 수 있습니다. 물론, 양식의 반복 제출을 방지하고 서버에서 반환된 오류를 처리하는 등 사용할 때 몇 가지 잠재적인 문제에 주의할 필요도 있습니다. 이 기사가 페이지를 새로 고치지 않고도 양식 제출을 구현하는 데 도움이 되기를 바랍니다. 🎜

위 내용은 jquery ajax 양식 제출로 페이지가 새로 고쳐지지 않습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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