Ajax внутри функции и возвращаемое значение…
Доброго времени суток!
Стоит такая задача: написать функцию, в которой выполняется ajax запрос, и вернуть результат этого запроса:
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .javascript.geshi_code {font-family:monospace;} .javascript.geshi_code .imp {font-weight: bold; color: red;} .javascript.geshi_code .kw1 {color: #000066; font-weight: bold;} .javascript.geshi_code .kw2 {color: #003366; font-weight: bold;} .javascript.geshi_code .kw3 {color: #000066;} .javascript.geshi_code .co1 {color: #006600; font-style: italic;} .javascript.geshi_code .co2 {color: #009966; font-style: italic;} .javascript.geshi_code .coMULTI {color: #006600; font-style: italic;} .javascript.geshi_code .es0 {color: #000099; font-weight: bold;} .javascript.geshi_code .br0 {color: #009900;} .javascript.geshi_code .sy0 {color: #339933;} .javascript.geshi_code .st0 {color: #3366CC;} .javascript.geshi_code .nu0 {color: #CC0000;} .javascript.geshi_code .me1 {color: #660066;} .javascript.geshi_code span.xtra { display:block; }
function somefunction(){
var src = "";
$.ajax({
url: 'http://vimeo.com/api/v2/video/44452539.json',
dataType: 'jsonp',
jsonp: 'callback',
success: function(response){
src = response;
}
})
return src;
}
Но, само-собой, javascript не дожидается окончания выполнения ajax и возвращает пустую строку. Как сделать так, чтобы эта функция возвращала именно результат запроса? Может есть способ остановить как-то выполнение сценария на время ajax запроса ?
Стоит такая задача: написать функцию, в которой выполняется ajax запрос, и вернуть результат этого запроса:
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .javascript.geshi_code {font-family:monospace;} .javascript.geshi_code .imp {font-weight: bold; color: red;} .javascript.geshi_code .kw1 {color: #000066; font-weight: bold;} .javascript.geshi_code .kw2 {color: #003366; font-weight: bold;} .javascript.geshi_code .kw3 {color: #000066;} .javascript.geshi_code .co1 {color: #006600; font-style: italic;} .javascript.geshi_code .co2 {color: #009966; font-style: italic;} .javascript.geshi_code .coMULTI {color: #006600; font-style: italic;} .javascript.geshi_code .es0 {color: #000099; font-weight: bold;} .javascript.geshi_code .br0 {color: #009900;} .javascript.geshi_code .sy0 {color: #339933;} .javascript.geshi_code .st0 {color: #3366CC;} .javascript.geshi_code .nu0 {color: #CC0000;} .javascript.geshi_code .me1 {color: #660066;} .javascript.geshi_code span.xtra { display:block; }
function somefunction(){
var src = "";
$.ajax({
url: 'http://vimeo.com/api/v2/video/44452539.json',
dataType: 'jsonp',
jsonp: 'callback',
success: function(response){
src = response;
}
})
return src;
}
Но, само-собой, javascript не дожидается окончания выполнения ajax и возвращает пустую строку. Как сделать так, чтобы эта функция возвращала именно результат запроса? Может есть способ остановить как-то выполнение сценария на время ajax запроса ?
1 ответов
В обычном ajax можно отключить асинхронный запрос параметром async: false
function somefunction(){
var src = "";
$.ajax({
async: false,
url: '/ajax.php',
success: function(response){
src = response;
}
}) ;
return src;
}
В jsonp такой номер не пройдёт.
в success и возвращайте переменную src
//...
success: function(response){
src = response;
return src;
}
//....