function updateServerList() {
var i;
for (i=0; i < servers.length; i++) {
var server = servers[i];
var ip = server['serverIp']
var html = constructServer(i);
var divId = '#server' + ip.replace(new RegExp("\\.", "mg"), "-");
var visible = $(divId).find(".server_body").is(":visible");
var div = $(divId);
div.html(html);
// Set div class.
var prevState = div.attr('class').substring(7)
if (prevState != server['state']) {
if (server['state'] == 'ok') {
console.debug(server);
div.slideUp('fast', function(server) {
$(this).removeClass();
$(this).addClass('server_ok');
var id = ipToId[server['serverIp']];
console.debug(id);
if (id == 0) {
adjacentIp = servers[1]['serverIp'];
adjacentDivId = '#server' + adjacentIp.replace(new RegExp('\\.', 'g'), '-');
$(adjacentDivId).before(this);
}
}).delay(1000);
div.slideDown();
}
}
}
Run Code Online (Sandbox Code Playgroud)
console.debug显示server为已定义,但在匿名函数内,server未定义.我出了什么问题?
因为server是函数的一个参数,它掩盖server了更高级别的值.您需要将服务器传递给函数,或者删除函数参数.我会做后者,因为slideUp没有给你一个传递参数的方法.你可以做到,但它不必要地复杂化; 它看起来像下面这样
div.slideUp('fast', (function(server) {
return function(){
// your stuff here, server is now 'closed in', i.e. in a closure
}
})(server)); // <-- this server is the current value in the loop
Run Code Online (Sandbox Code Playgroud)
你在这里做的是立即调用一个新函数,传入参数服务器,并返回一个接收该值的新函数.