从AJAX中的onreadystatechange事件返回值

时间:2013-10-10 14:08:57

标签: javascript jquery ajax

我正在尝试在下面的代码中为变量val分配一个值:

var cmdValue = "/cmd/fetch?x=";
var val;
var returned_data;

function what(){
    val = update('#TAG#');
}


function update(tag) {
    var req1 = newXMLHttpRequest();
    req1.open("GET",cmdValue + tag, true);
    req1.send("");

    return req1.onreadystatechange= function () {
        if (req1.readyState == 4 && req1.status == 200) {
            returned_data = req1.responseText;
            return returned_data;
        }else{

        }
    };
}

我正在跟踪Firebug中的变量,结果证明val已分配了该函数。有没有办法让代码运行,然后将值赋给变量val

2 个答案:

答案 0 :(得分:8)

在异步编程中,您 return数据,因为您不知道该数据何时可用 - 它是异步的。

进行异步编程的方法是使用事件和/或回调。

示例:

var cmdValue = "/cmd/fetch?x=";
var val;
var returned_data;
var performSomeAction = function(returned_data) {
    val = returned_data;
}

function what(){
    update('#TAG#',performSomeAction);
}



function update(tag,callback) {
    var req1 = newXMLHttpRequest();
    req1.open("GET",cmdValue + tag, true);
    req1.send("");

    req1.onreadystatechange= function () {
        if (req1.readyState == 4 && req1.status == 200) {
            returned_data = req1.responseText;
            //fire your callback function
            callback.apply(this,[returned_data]);
        }else{

        }
    };
}

这个问题是关于SO的最常见问题之一,至少在涉及javascript标签时 - 请在问自己之前搜索类似的问题。

答案 1 :(得分:-1)

// should have a space after new or was did u notice it 
var req1 = new XMLHttpRequest();