javascript 匿名函数

Posted 牵牛花

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript 匿名函数相关的知识,希望对你有一定的参考价值。

匿名函数没有实际名字,也没有指针,怎么执行滴?
其实大家可以看看小括号的意义就应该可以理解。小括号有返回值,也就是小括号内的函数或者表达式的返回值,所以说小括号内的function返回值等于小括号的返回值,不难理解 (function(){})()可以将没有名字的函数执行了把…
关于匿名函数写法,很发散~
最常见的用法:

复制代码 代码如下:

(function() {
alert(‘water‘);
})();

=====================================================================================================

如果看不懂匿名函数,看一下这个表达式

var square = function(x){return x*x;}//把函数赋值给了一个变量

表达式

var tensquare = (function(x){return x*x;})(10));/函数表达式定义后立即调用

javascript权威指南--函数

=====================================================================================================

当然也可以带参数:

复制代码 代码如下:

(function(o) {
alert(o);
})(‘water‘);


想用匿名函数的链式调用?很简单:

复制代码 代码如下:

(function(o) {
alert(o);
return arguments.callee;
})(‘water‘)(‘down‘);


常见的匿名函数都知道了,看看不常见的:

复制代码 代码如下:

~(function(){
alert(‘water‘);
})();//写法有点酷~

 

复制代码 代码如下:

void function(){
alert(‘water‘);
}();//据说效率最高~

 

复制代码 代码如下:

+function(){
alert(‘water‘);
}();

 

复制代码 代码如下:

-function(){
alert(‘water‘);
}();

 

复制代码 代码如下:

~function(){
alert(‘water‘);
}();

 

复制代码 代码如下:

!function(){
alert(‘water‘);
}();

 !-+~ 这些事一元运算符,优先级最高的,会把后面的函数调用作为一个整体,就类似与

!(function(){ 
alert(‘water‘); 
}());

复制代码 代码如下:

(function(){
alert(‘water‘);
}());//有点强制执行的味道~


这么多写法贱卖啦~呵呵,其实有些人考虑到写法的效率问题,如果可以,给我一个数据把,自我感觉这些写法是有效率问题,但是应该是微乎其微而已(或许不对),我会随便选一个用~  








































以上是关于javascript 匿名函数的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript中的匿名函数立即执行函数和闭包

javascript匿名函数与闭包

JavaScript 函数

详谈JavaScript 匿名函数及闭包

Javascript的匿名函数与自执行

Javascript的匿名函数与自执行