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
------解决方案--------------------
这叫"匿名函数" ,一般来说,函数的名字是为了以后可以继续调用.
而有些函数只需执行一次,就懒得给它起名字了