表达式函数深入了解javascript系列学习笔记(二):揭秘命名函数表达式


查了好多资料,发现还是不全,干脆自己整理吧,至少保证在我的做法正确的,以免误导读者,也是给自己做个记录吧!

(function foo(){}); // 函数表达式:包含在分组操作符内
1.被括号括住的(function foo(){}),他是表达式的原因是因为括号 ()是一个分组操作符,它的内部只能包含表达式

    (var x = 5); // 分组操作符,只能包含表达式而不能包含语句:这里的var就是语句,所以是错误的写法

    ({x:"lala"})//这样写是合法的,因为分组操作符,也就是这对小括号,会让解析器强制将JSON的花括号解析成表达式而不是代码块。

    { "x": 5 }; // "{" 和 "}" 做解析成代码块

    ({ "x": 5 }); // 分组操作符强制将"{" 和 "}"作为对象字面量来解析

    2.函数声明只能出现在程序或函数体

    内。从句法上讲,它们 不能出现在Block(块)({ ... })中,例如不能出现在 if、while 或 for 语句中。

    每日一道理
“多难兴才”曾一度被人定为规律。请看:屈原被放逐而作《离骚》;司马迁受宫刑而作《史记》;欧阳修两岁丧父笃学而成才;曹雪芹举家食粥而写出了不朽的《红楼梦》;越王勾践卧薪尝胆而雪洗国耻;韩信遭胯下辱而统率百万雄兵……他们都是在与逆境搏斗中成为伟人的!
 1  // 千万别这样做!
 2   // 因为有的浏览器会返回first的这个function,而有的浏览器返回的倒是第二个
 3 
 4   if (true) {
 5     function foo() {
 6       return 'first';
 7     }
 8   }
 9   else {
10     function foo() {
11       return 'second';
12     }
13   }
14   foo();
15 
16   // 相反,这样情况,我们要用函数表达式
17   var foo;
18   if (true) {
19     foo = function() {
20       return 'first';
21     };
22   }
23   else {
24     foo = function() {
25       return 'second';
26     };
27   }
28   foo();
3.最好不要应用定名函数表达式;用定名函数表达式是为了使调试更便利。

    如果应用定名函数表达式,在调用的时候不要用函数的标识符。及var a = function b(){};在调用的时候应用a();来调用,而不是应用b()来调用。因为为不同的浏览器对函数表达式的解析方法不一样.

    由于编程经验尚浅,文章里面有些部份看的晕晕的

    

 

    

 

 

文章结束给大家分享下程序员的一些笑话语录: 面试官:熟悉哪种语言
应聘者:JAVA
面试官:知道什么叫类么
应聘者:我这人实在,工作努力,不知道什么叫累
面试官:知道什么是包?
应聘者:我这人实在 平常不带包 也不用公司准备了
面试官:知道什么是接口吗?
应聘者:我这个人工作认真。从来不找借口偷懒
面试官:知道什么是继承么
应聘者:我是孤儿没什么可以继承的
面试官:知道什么叫对象么?
应聘者:知道,不过我工作努力,上进心强,暂时还没有打算找对象。
面试官:知道多态么?
应聘者:知道,我很保守的。我认为让心爱的女人为了自已一时的快乐去堕胎是不道德的行为!请问这和C#有什么关系??

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值