日期:2014-05-16  浏览次数:20450 次

javascript 中很多直接new function(){}是什么意思
直接 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是什么意思..

------解决方案--------------------


动态生成一个function


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

------解决方案--------------------
其实就是把函数的定义和执行放在一块。与传统的先定义后执行的方式相比,减少了全局变量。
------解决方案--------------------
将这个对象初始化之后,然后释放掉。
------解决方案--------------------
我回家翻了翻书!就在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
------解决方案--------------------
这叫"匿名函数" ,一般来说,函数的名字是为了以后可以继续调用.
而有些函数只需执行一次,就懒得给它起名字了