注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

前端攻城师 郭培的博客

Be the best you can

 
 
 

日志

 
 
关于我

前端技术:http://hszy00232.blog.163.com/ 前端设计:http://blog.sina.com.cn/hsjs00232 职业:web前端工程师 现居地:北京 My QQ:365246295 Mail:hszy00232@163.com

网易考拉推荐

Javascript中匿名函数的调用方式  

2011-03-04 16:22:36|  分类: javascript |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

在使用javascript时我们经常会遇到一种在定义时不带名称的函数,即匿名函数,它的应用很广泛。这篇文档暂不讨论它用的何处,主要是讨论匿名函数的调用。匿名函数最常用的调用方式有现两种:

1 //方式1,调用函数,得到返回值。强制运算符使函数调用执行
2  (function(x,y){
3 alert(x+y);
4 return x+y;
5 }(3,4));
1 //方式二,调用函数,得到返回值。强制函数直接量执行再返回一个引用,引用再去调用执行
2  (function(x,y){
3 alert(x+y);
4 return x+y;
5 })(3,4);
6

这两种方法的执行效率是一样的,但是jslint中推荐使用方式1。

下面我们介绍不常用的方式3及其变种

1 //方式三,调用函数,忽略返回值
2   void function(x) {
3 x = x-1;
4 alert(x);
5 }(9);

1 //变种一,调用函数
2  + function(x) {
3 x = x-1;
4 alert(x);
5 }(9);

1 //变种一,调用函数
2  - function(x) {
3 x = x-1;
4 alert(x);
5 }(9);

通过在匿名函数前添加运算符,达到强制匿名函数执行的效果。

有一种特别容易使人迷惑的调用匿名函数的方式:

1 //变种三,调用函数
2 var c= function(x) {
3 x = x-1;
4 alert(x);
5 }(9);

这种方式也可以调用匿名函数,这不是使用变量形式自定义函数嘛?哦,是吗,不是吧,后面还有个()呢。

关键是"="运算符的使用,哈哈,看明白了吗。

  评论这张
 
阅读(1508)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017