prototype.js - javascript函数表达式有存在的必要吗?
PHP中文网
PHP中文网 2017-04-10 14:30:14
0
2
463

小白,正在学习js,顺带看一点儿prototype.js的源码,发现了很多函数表达式,这么做有必要吗?为什么不直接取函数表达式的运算结果呢?

比如下面这个,感觉怎么执行结果都是false,为啥不直接 var Class = true ?

  var IS_DONTENUM_BUGGY = (function(){
    for (var p in { toString: 1 }) {
      if (p === 'toString') return false;
    }
    return true;
  })();
PHP中文网
PHP中文网

认证0级讲师

reply all(2)
Ty80

你这问题槽点很多,我都不知道从哪开始...O__O"…
首先,你这代码不完整啊,至少也是

var Class = (function() {

  var IS_DONTENUM_BUGGY = (function(){
    for (var p in { toString: 1 }) {
      if (p === 'toString') return false;
    }
    return true;
  })();

  /*do something*/
})()

后边正事都没干的,谁知道Class的值会是啥?
当然,我们可以知道IS_DONTENUM_BUGGY是啥!
你觉得IS_DONTENUM_BUGGYfalse,是因为你使用的现代浏览器
而在IE6/7/8(万恶的IE)里IS_DONTENUM_BUGGYtrue

这里涉及到一个概念DontEnum(ES5里称之为Enumerable),即属性不能被for..in循环枚举
比如说

var obj = { 
    name:"XiaoMing",  
    get:function() {return this.name}  
};
for(var prop in obj) {  
    console.log(prop); //会输出name,get   
} 

for..in不会枚举出toString,isPrototypeOf,valueOf之类的内置属性,它们是不可枚举的
如果我们重写它们(就像你的函数一样),不同的浏览器(没错,我就是说的IE)结果就会有分歧,需要IS_DONTENUM_BUGGY进行标识。
所以函数表达式大部分时候,至少在你这里,还是很有用的。

最后,prototype.js已经是太古时期使用的框架啦,LZ你最好还是换个例子研究吧

迷茫

使用函数表达式的好处是

  1. 避免新增或覆盖全局变量
  2. 动态求值

例子:http://jsbin.com/sirup/3/edit?js,output

Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template