我很好奇,爲什麼這是行不通的,下面的代碼:如何用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