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 get_sesPriv() {
var sesPriv;
var xmlhttp = getXmlHttp();
xmlhttp.open('GET', 'sesPriv.php', true)
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
// в этом моменте нужно записать знаечение и использовать его дальше в функции
sesPriv = xmlhttp.responseText;
alert(sesPriv); // этот алерт выведется вторым по счету со значение 2(то что ожидается)
}
}
//ипользовать например здесь
alert(sesPriv); // этот алерт выведется первым со значением undefined
xmlhttp.send(null);
}
Использование глобальных переменных не помогает.
Вообще всей задачей функции get_sesPriv является сделать return того что приходит в xmlhttp.responseText.
1 ответов
если я правильно понял, то нужен синхронный вызов:
http://xmlhttprequest.ru/book/export/html/4
что-нибудь такое
function get_sesPriv() {
var sesPriv;
var xmlhttp = getXmlHttp();
xmlhttp.open('GET', 'sesPriv.php', false); // false - синхронно
xmlhttp.send(null);
if (xmlhttp.status == 200) {
// в этом моменте нужно записать знаечение и использовать его дальше в функции
sesPriv = xmlhttp.responseText;
alert(sesPriv); // этот алерт выведется со значение 2(то что ожидается)
}
//ипользовать например здесь
return sesPriv;
}
Начнем с того, что обращение к переменной sesPriv до xmlhttp.send(null); бессмысленно, так как значение переменной присвоится только после возникновения события readystatechange на ответ сервера. Ну а ответ сервера не может случиться, так как запрос к нему еще не был отправлен - как раз xmlhttp.send(null);.
Вообще Javascript отличается своей асинхронностью... Вы уверены, что обращение к этой переменной происходит после ее инициализации?
Из Вашего вопроса также не понятен контекст... Что именно возвращается с сервера? Уверены ли вы, что действительно возвращается?)
Определите переменную раньше, чем будете в нее что-то писать, но на том же уровне видимости, на котором будете ее использовать. Например:
function get_sesPriv() {
var xmlhttp = getXmlHttp();
var sesPriv;
//...
//ипользовать например здесь
alert(sesPriv);
xmlhttp.send(null);
}
Должно сработать.