>  기사  >  웹 프론트엔드  >  jquery ajax_jquery에서 jsonp 사용 제한 사항에 대한 솔루션

jquery ajax_jquery에서 jsonp 사용 제한 사항에 대한 솔루션

WBOY
WBOY원래의
2016-05-16 17:13:081129검색

jsonp는 도메인 간 Ajax 호출 문제를 해결합니다. 왜 도메인 간 Ajax 호출을 해야 합니까? 이런 방식으로 한 애플리케이션은 프런트엔드의 js를 통해 (다른 도메인 이름으로) 다른 애플리케이션의 API를 직접 호출할 수 있습니다.
실제 애플리케이션에서도 jsonp를 사용해 보았지만 이전에는 get 요청만 보낼 수 있다는 제한 사항을 알고 있었습니다. get 요청의 단점은 요청 길이가 제한된다는 것입니다.
오늘 jsonp의 또 다른 제한 사항(jquery ajax의 컨텍스트에서)을 발견했습니다. $.ajax의 오류 콜백이 트리거되지 않습니다. 샘플 코드는 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.

$.ajax({
dataType : 'jsonp',                                                                                                    ~                                    .
이 제한은 jsonp의 구현 메커니즘에 따라 결정됩니다.

해결책:

jquery 플러그인 사용 - jquery-jsonp, https://github.com/jaubourg/jquery-jsonp
샘플 코드:

코드 복사


코드는 다음과 같습니다.



코드 복사

코드는 다음과 같습니다.

$.jsonp({ url : '' , 성공: 함수(데이터) { }, 오류: 함수(xOptions, textStatus) {
console.log(textStatus);
}
}) ;



jsonp 요청에 404 오류 등 오류가 있는 경우 오류 콜백 함수가 실행되고 "error"라는 문자열이 출력됩니다.
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.