> 웹 프론트엔드 > JS 튜토리얼 > 비동기식 또는 동기식 AJAX를 사용하는 경우

비동기식 또는 동기식 AJAX를 사용하는 경우

藏色散人
풀어 주다: 2019-01-22 14:39:54
원래의
3461명이 탐색했습니다.

AJAX는 Asynchronous JavaScript and XML의 약자이며 웹 페이지를 비동기적으로 업데이트할 수 있는 기술입니다. 즉, 페이지에서 소량의 데이터만 변경될 때 브라우저가 전체 페이지를 다시 로드할 필요가 없습니다. AJAX는 업데이트된 정보만 서버에 전달합니다.

비동기식 또는 동기식 AJAX를 사용하는 경우

표준 웹 애플리케이션은 웹 방문자와 서버 간의 상호 작용을 동기식으로 처리합니다. 이는 서버가 멀티태스킹을 수행하지 않는다는 의미입니다. 버튼을 클릭하면 서버로 메시지가 전송되고 응답이 반환됩니다. 응답이 수신되고 페이지가 업데이트될 때까지 다른 페이지 요소와 상호 작용할 수 없습니다.

분명히 이러한 지연은 웹 방문자의 경험에 부정적인 영향을 미칠 수 있으므로 AJAX를 사용하게 됩니다.

AJAX란 무엇인가요?

AJAX는 프로그래밍 언어가 아니라 웹 서버와 통신하는 클라이언트 측 스크립트(예: 사용자 브라우저에서 실행되는 스크립트)를 통합하는 기술입니다. 게다가 그 이름은 다소 오해의 소지가 있습니다. AJAX 애플리케이션은 XML을 사용하여 데이터를 보낼 수도 있지만 일반 텍스트나 JSON 텍스트만 사용할 수도 있습니다. 그러나 일반적으로 브라우저의 XMLHttpRequest 개체(서버에서 데이터를 요청하기 위해)와 JavaScript를 사용하여 데이터를 표시합니다.

AJAX: 동기식 또는 비동기식

AJAX는 실제로 서버에 동기식 및 비동기식으로 액세스할 수 있습니다.

동기식에서는 스크립트가 중지되고 계속하기 전에 서버가 응답을 다시 보낼 때까지 기다립니다.

Async, 스크립트를 통해 페이지 처리를 계속하고 페이지 도착 시 응답을 처리할 수 있습니다.

요청을 동기적으로 처리하는 것은 페이지를 다시 로드하는 것과 유사하지만 전체 페이지가 아닌 요청된 정보만 다운로드합니다. 따라서 AJAX를 동기적으로 사용하는 것이 전혀 사용하지 않는 것보다 빠르지만, 페이지와 추가 상호 작용을 하기 전에 방문자는 다운로드를 기다려야 합니다. 일반적으로 사용자는 페이지가 로드될 때까지 기다려야 하는 경우가 있다는 것을 알고 있지만 사이트에서 지속적이고 눈에 띄는 지연을 경험하는 데 익숙하지 않습니다.

요청을 비동기적으로 처리하면 방문자가 웹 페이지와 계속 상호 작용할 수 있으므로 요청된 정보가 백그라운드에서 처리되고 응답이 도착하면 페이지가 업데이트되므로 서버에서 검색할 때 지연이 발생하지 않습니다. 또한 응답이 지연되더라도(예: 매우 큰 데이터의 경우) 페이지의 다른 곳에서 시간을 소비하기 때문에 사용자는 이를 인식하지 못할 수 있습니다. 그러나 대부분의 응답에서 방문자는 서버에 요청이 이루어졌다는 사실조차 인식하지 못합니다.

따라서 AJAX를 사용하는 가장 좋은 방법은 가능할 때마다 비동기 호출을 사용하는 것입니다. 이는 AJAX의 기본 설정입니다.

동기식 AJAX를 사용하는 이유

비동기식 호출이 이렇게 향상된 사용자 경험을 제공한다면 AJAX가 동기식 호출을 수행하는 방법을 제공하는 이유는 무엇입니까?

비동기식 호출이 대부분의 경우 최선의 선택이지만 좋은 옵션은 아닙니다. 이 경우 특정 서버 측 프로세스가 완료될 때까지 방문자가 웹 페이지와 계속 상호 작용하도록 허용하는 것은 의미가 없습니다.

많은 경우 Ajax를 전혀 사용하지 않고 전체 페이지를 다시 로드하는 것이 더 좋습니다. AJAX의 동기 옵션은 비동기 호출을 사용할 수 없지만 전체 페이지를 다시 로드하지 않는 몇 가지 경우에 유용합니다. 예를 들어, 주문이 중요한 일부 거래를 처리해야 할 수 있습니다. 사용자가 무언가를 클릭한 후 웹페이지에서 확인 페이지를 반환해야 하는 상황을 생각해 보세요. 이를 위해서는 동기식 요청이 필요합니다.

위 내용은 비동기식 또는 동기식 AJAX를 사용하는 경우의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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