今天用jQuery回调函数的时候顿了下,想弄清楚
有区别吗?
发现有区别,区别在于,前者元素隐藏了后,弹出aaa,而后者是先弹出aaa之后再隐藏元素。为什么会出现这种情况了,[color=red]感觉都是回调函数[/color]啊,效果应该一样啊!
怀着疑问上网查了资料,终于找到如下文章
[url]http://www.html-js.com/article/1592[/url],里面有我想要的答案:[color=red]当我们将一个回调函数作为参数传递给另一个函数是,我们仅仅传递了函数定义。我们并没有在参数中执行函数。我们并不传递像我们平时执行函数一样带有一对执行小括号()的函数[/color]
回到我之前的问题,前者是回调函数,只是存在的是匿名函数的定义(称引用也行);而后者既不是函数的定义,也不是函数的引用,仅仅只是[color=red]函数的调用(带了括号)[/color],那么显然我们之前的[color=red]感觉都是回调函数[/color]是错的,第二种情况不是回调函数,因而出现了先弹出aaa后隐藏元素
$btn.hide(1000,function(){
alert("aaa");
});
$btn.hide(1000,alert("aaa"));
有区别吗?
发现有区别,区别在于,前者元素隐藏了后,弹出aaa,而后者是先弹出aaa之后再隐藏元素。为什么会出现这种情况了,[color=red]感觉都是回调函数[/color]啊,效果应该一样啊!
怀着疑问上网查了资料,终于找到如下文章
[url]http://www.html-js.com/article/1592[/url],里面有我想要的答案:[color=red]当我们将一个回调函数作为参数传递给另一个函数是,我们仅仅传递了函数定义。我们并没有在参数中执行函数。我们并不传递像我们平时执行函数一样带有一对执行小括号()的函数[/color]
回到我之前的问题,前者是回调函数,只是存在的是匿名函数的定义(称引用也行);而后者既不是函数的定义,也不是函数的引用,仅仅只是[color=red]函数的调用(带了括号)[/color],那么显然我们之前的[color=red]感觉都是回调函数[/color]是错的,第二种情况不是回调函数,因而出现了先弹出aaa后隐藏元素