Carcione의 답변을 사용하고 JSON을 사용하도록 수정했습니다.
function getUrlJsonSync(url){
var jqxhr = $.ajax({
type: "GET",
url: url,
dataType: 'json',
cache: false,
async: false
});
// 'async' has to be 'false' for this to work
var response = {valid: jqxhr.statusText, data: jqxhr.responseJSON};
return response;
}
function testGetUrlJsonSync()
{
var reply = getUrlJsonSync("myurl");
if (reply.valid == 'OK')
{
console.dir(reply.data);
}
else
{
alert('not valid');
}
}
'JSON' 의 dataType 을 추가하고 .responseText 를 responseJSON으로 변경했습니다. .
또한 반환 된 객체 의 statusText 속성을 사용하여 상태를 검색했습니다 . 이것은 JSON이 유효한지 여부가 아니라 Ajax 응답의 상태입니다.
백엔드는 올바른 (잘 구성된) JSON으로 응답을 리턴해야합니다. 그렇지 않으면 리턴 된 오브젝트가 정의되지 않습니다.
원래 질문에 대답 할 때 고려해야 할 두 가지 측면이 있습니다. 하나는 Ajax에 동 기적으로 수행하도록 지시하고 ( async : false 설정 ) 다른 하나는 콜백 함수가 아닌 호출 함수의 return 문을 통해 응답을 반환합니다.
POST로 시도해 보았습니다.
GET을 POST로 변경하고 postdata를 추가했습니다 .
function postUrlJsonSync(url, postdata){
var jqxhr = $.ajax({
type: "POST",
url: url,
data: postdata,
dataType: 'json',
cache: false,
async: false
});
// 'async' has to be 'false' for this to work
var response = {valid: jqxhr.statusText, data: jqxhr.responseJSON};
return response;
}
위의 코드 는 async 가 false 인 경우에만 작동합니다 . async : true 로 설정 한 경우 , 반환 된 객체 jqxhr 은 AJAX 호출이 반환 될 때 유효하지 않습니다. 나중에 비동기 호출이 완료된 경우에만 응답 변수 를 설정하기에는 너무 늦습니다 .
beforecreate
.