动态生成一个function
== 思想重于技巧 ==

解决方案 »

  1.   

    new 不是实例化一个对象吗?
      

  2.   

    这是用构造函数的形式生成一个function
    function是Function类的实例
      

  3.   

    var foo01 = function() 
    最普通的function使用方式,定一个JavaScript函数。两种写法表现出来的运行效果完全相同,唯一的却别是后一种写法有较高的初始化优先级。在大扩号内的变量作用域中,this指代foo01的所有者,即window对象。 
    var foo02 = new function() 
    好像是定一个函数。但是实际上这是定一个JavaScript中的用户自定义对象,不过这里是个匿名类。这个用法和函数本身的使用基本没有任何关系,在大扩号中会构建一个变量作用域,this指代这个作用域本身。
    var foo3 = new Function(...);
    使用系统内置函数对象来构建一个函数,这和方法一中的第一种方式在效果和初始化优先级上都完全相同,就是函数体以字符串形式给出。 
    var foo4 = Function(..);
    不过不清楚不用new来生成有没有什么副作用,这也体现了JavaScript一个最大的特性:灵活!能省就省。 
      

  4.   

    定义了一个对象?那这个对象叫什么?怎么来用它..如果是动态生成一个function 那怎么不直接写function(){} 这样写,又为何呢?谢谢解答一下,我脑子都想爆炸了。
      

  5.   

    new function(){
    this.a = "aa";
    alert(this.a);
    };
    (function(){
    this.a = "aa";
    alert(this.a);
    })();//这两个是一样的 
      

  6.   

    我回家翻了翻书!就在JavaScript核心技术的自定义对象中看到:可以用旧的函数来创建一次性对象:var variable = new function(){     this.variA="Va1";     this.variB="Va2";     this.method=function(){                                  return variA + variB;                            }}http://blog.csdn.net/xiaofanku/archive/2008/02/19/2107878.aspx
      

  7.   

    我觉得只要你不返回值,可以不用把对象赋值给变量,要调用时直接写:this.variable周可以了
      

  8.   

    这个代码有点点出入哈,new function是生成一个类,而后者只是一个匿名函数,他们的this指的也不同,前者的this就是自身,而后者的this则指向了上层域。