Переменные в функциях
Проблема с переменными и возвращением из функции. Этот код поможет подключиться к базе данных MySQL и выбрать расстояние между двумя городами. переменная ret_pomoc
это расстояние.
Значение в ret_pomoc
Мне нужно использовать в другой функции, например, в another_fuction()
,
Вот код:
var ret_pomoc;
var vzdialenost;
function ajaxFunction(mesto_1,mesto_2){
var ajaxRequest; // The variable that makes Ajax possible!
try{
// Opera 8.0+, Firefox, Safari
ajaxRequest = new XMLHttpRequest();
}catch (e){
// Internet Explorer Browsers
try{
ajaxRequest = new ActiveXObject("Msxml2.XMLHTTP");
}catch (e) {
try{
ajaxRequest = new ActiveXObject("Microsoft.XMLHTTP");
}catch (e){
// Something went wrong
alert("Your browser broke!");
return false;
}
}
}
// Create a function that will receive data
// sent from the server and will update
// div section in the same page.
ajaxRequest.onreadystatechange = function(){
if(ajaxRequest.readyState == 4){
var ajaxDisplay = document.getElementById('mapa2');
ajaxDisplay.value = ajaxRequest.responseText;
ret_pomoc=ajaxDisplay.value; //HERE IS KEY VARIABLE
console.log(ret_pomoc); // 1. Here it is OK show 91
}
}
console.log(ret_pomoc); // 2. Here it does not work show undefined and return does not work
// Now get the value from user and pass it to
// server script.
var z_mesta = mesto_1;
var do_mesta = mesto_2;
var queryString = "?z_mesta=" + z_mesta ;
queryString += "&do_mesta=" + do_mesta;
ajaxRequest.open("GET", "pristup.php" +
queryString, true);
ajaxRequest.send(null);
}
Мне нужно использовать значение из ret_pomoc
в другой функции
function another_function(){
vzdialenost=ajaxFunction('Bratislava','Nitra') + ajaxFunction('Poprad','Nitra') ;
}
1 ответ
Ajax-запрос работает асинхронно, поэтому способ сделать это - передать callback
функция, которая будет вызвана, когда ответ вернется.
Понимание функций обратного вызова в Javascript
function some_function2(url, callback) {
var httpRequest; // create our XMLHttpRequest object
if (window.XMLHttpRequest) {
httpRequest = new XMLHttpRequest();
} else if (window.ActiveXObject) {
// Internet Explorer is stupid
httpRequest = new
ActiveXObject("Microsoft.XMLHTTP");
}
httpRequest.onreadystatechange = function() {
// inline function to check the status
// of our request
// this is called on every state change
if (httpRequest.readyState === 4 &&
httpRequest.status === 200) {
callback.call(httpRequest.responseXML);
// call the callback function
}
};
httpRequest.open('GET', url);
httpRequest.send();
}
// call the function
some_function2("text.xml", function() {
console.log(this);
});
console.log("this will run before the above callback");