我很好奇,为什么这是行不通的,下面的代码:如何用ajax更改此变量?
function Ajax(sUrl, fCallback) {
var url = sUrl || '';
var callback = fCallback || function() {};
var xmlhttp = (function() {
if (window.XMLHttpRequest) {
return new XMLHttpRequest();
} else if (window.ActiveXObject) {
try {
return new ActiveXObject("Msxml2.XMLHTTP.6.0");
} catch (e) {
try {
return new ActiveXObject("Msxml2.XMLHTTP.3.0");
} catch (err) {
return new ActiveXObject("Microsoft.XMLHTTP");
}
}
} else {
return null;
}
}());
this.setUrl = function (newUrl) {
url = newUrl;
};
this.setCallback = function (func) {
callback = func;
};
this.request = function (method, data) {
if (xmlhttp === null) { return false; }
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState === 4) {
callback(xmlhttp.status, xmlhttp.responseXML, xmlhttp.responseText);
}
};
data = data || '';
data = encodeURIComponent(data);
if ((/post/i).test(method)) {
xmlhttp.open('POST', url);
xmlhttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xmlhttp.send(data);
} else {
var uri = data === '' ? url : url + '?' + data;
xmlhttp.open('GET', uri);
xmlhttp.send();
}
return true;
};
return this;
}
var ajax = new Ajax(''); // sets the url, not necessary for this demonstration
var changed = false;
function change() {
changed = true;
}
function foo() {
ajax.setCallback(change);
ajax.request();
alert(changed);
}
foo();
这里有一个小提琴:http://jsfiddle.net/dTqKG/
我觉得像change
功能将创建一个闭包的确会更改changed
变量。有谁知道发生了什么事?
撇开:你不需要从你作为构造函数调用的函数中返回'this':这将自动发生,通常的做法是让它自动发生(只是不要返回还要别的吗)。 – nnnnnn 2012-01-01 10:26:46
@nnnnnn,我想我同意。 。 。看起来我一直在读太多的Crockford @ _ @谢谢! – dunnza 2012-01-02 12:24:35