javascript 中很多直接new function(){}是什么意思

时间:2022-11-11 20:18:06
直接 new 了一下

new function() {
        var b = navigator.userAgent.toLowerCase();

        // Figure out what browser is being used
        jQuery.browser = {
                safari: /webkit/.test(b),
                opera: /opera/.test(b),
                msie: /msie/.test(b) && !/opera/.test(b),
                mozilla: /mozilla/.test(b) && !/compatible/.test(b)
        };

        // Check to see if the W3C box model is being used
        jQuery.boxModel = !jQuery.browser.msie || document.compatMode == "CSS1Compat";
};

小弟一般 是 var obj = new function();

不知道这样直接new是什么意思..

17 个解决方案

#1




动态生成一个function


== 思想重于技巧 ==

#2


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

#3


可以说是定义了一个对象!

#4


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

#5


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

#6


定义了一个对象?那这个对象叫什么?怎么来用它..

如果是动态生成一个function 那怎么不直接写function(){} 这样写,又为何呢?

谢谢解答一下,我脑子都想爆炸了。

#7


能贴上全码吗

#8


new function(){
this.a = "aa";
alert(this.a);
};
(function(){
this.a = "aa";
alert(this.a);
})();


//这两个是一样的 

#9


其实就是把函数的定义和执行放在一块。与传统的先定义后执行的方式相比,减少了全局变量。

#10


不明白说的什么意思

#11


将这个对象初始化之后,然后释放掉。

#12


我回家翻了翻书!就在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

#13


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

#14


 楼上这位兄弟辛苦了...

#15


这叫"匿名函数" ,一般来说,函数的名字是为了以后可以继续调用.
而有些函数只需执行一次,就懒得给它起名字了

#16


我也正在考虑这个问题

#17


引用 8 楼 tantaiyizu 的回复:
JScript code
new function(){
    this.a = "aa";
    alert(this.a);
};
(function(){
    this.a = "aa";
    alert(this.a);
})();


//这两个是一样的



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

#1




动态生成一个function


== 思想重于技巧 ==

#2


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

#3


可以说是定义了一个对象!

#4


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

#5


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

#6


定义了一个对象?那这个对象叫什么?怎么来用它..

如果是动态生成一个function 那怎么不直接写function(){} 这样写,又为何呢?

谢谢解答一下,我脑子都想爆炸了。

#7


能贴上全码吗

#8


new function(){
this.a = "aa";
alert(this.a);
};
(function(){
this.a = "aa";
alert(this.a);
})();


//这两个是一样的 

#9


其实就是把函数的定义和执行放在一块。与传统的先定义后执行的方式相比,减少了全局变量。

#10


不明白说的什么意思

#11


将这个对象初始化之后,然后释放掉。

#12


我回家翻了翻书!就在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

#13


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

#14


 楼上这位兄弟辛苦了...

#15


这叫"匿名函数" ,一般来说,函数的名字是为了以后可以继续调用.
而有些函数只需执行一次,就懒得给它起名字了

#16


我也正在考虑这个问题

#17


引用 8 楼 tantaiyizu 的回复:
JScript code
new function(){
    this.a = "aa";
    alert(this.a);
};
(function(){
    this.a = "aa";
    alert(this.a);
})();


//这两个是一样的



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