如果您<script type='text/javascript'>
不在<body>
. 尝试类似:
if($('#name')){
$('#usernameLoading').show();
$.post('check', {name: $('#name').val(), platform: $('#platform').val()}, function(response){
$('#usernameResult').fadeOut();
setTimeout(function(){
//need your usernameResult and response to be dealt with here
}, 400);
});
return false;
}
你应该注意到我改变了你传入的执行函数setTimeout()
。您不能将执行的函数发送到这样的参数中,除非您希望它在现场执行。但是,您可以创建您的finishAjax
方法,然后在没有参数的情况下传递它,例如:
setTimeout(finishAjax, 400);
不幸的是,setTimeout()
没有可以将函数参数传递给的参数。要了解我在说什么,请查看以下内容:
function lameFunc(func, funcArg){
return func(funcArg);
}
function lameQuote(q){
return q;
}
var whatever = lameFunc(lameQuote, 'var whatever is now this String');
这是一个将参数传递给另一个函数的函数示例。lameQuote
您可以与匿名函数进行交换,并仍然向它传递一个参数,例如:
var someVar = lameFunc(function(arg){return arg;}, 'This String Will Go In arg and, therfore, someVar');
这就是setTimeout()
内部的工作方式,除了它不需要另一个可以传递给你的函数的参数,所以它更像是:
function lameFunc(func){
return func();
}
当然,显然还有更多的差异,但这应该可以教给你一些东西。