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类的实例
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一个最大的特性:灵活!能省就省。
最普通的function使用方式,定一个JavaScript函数。两种写法表现出来的运行效果完全相同,唯一的却别是后一种写法有较高的初始化优先级。在大扩号内的变量作用域中,this指代foo01的所有者,即window对象。
var foo02 = new function()
好像是定一个函数。但是实际上这是定一个JavaScript中的用户自定义对象,不过这里是个匿名类。这个用法和函数本身的使用基本没有任何关系,在大扩号中会构建一个变量作用域,this指代这个作用域本身。
var foo3 = new Function(...);
使用系统内置函数对象来构建一个函数,这和方法一中的第一种方式在效果和初始化优先级上都完全相同,就是函数体以字符串形式给出。
var foo4 = Function(..);
不过不清楚不用new来生成有没有什么副作用,这也体现了JavaScript一个最大的特性:灵活!能省就省。
#6
定义了一个对象?那这个对象叫什么?怎么来用它..
如果是动态生成一个function 那怎么不直接写function(){} 这样写,又为何呢?
谢谢解答一下,我脑子都想爆炸了。
如果是动态生成一个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
可以用旧的函数来创建一次性对象:
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
这个代码有点点出入哈,new function是生成一个类,而后者只是一个匿名函数,他们的this指的也不同,前者的this就是自身,而后者的this则指向了上层域。
#1
动态生成一个function
== 思想重于技巧 ==
#2
new 不是实例化一个对象吗?
#3
可以说是定义了一个对象!
#4
这是用构造函数的形式生成一个function
function是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一个最大的特性:灵活!能省就省。
最普通的function使用方式,定一个JavaScript函数。两种写法表现出来的运行效果完全相同,唯一的却别是后一种写法有较高的初始化优先级。在大扩号内的变量作用域中,this指代foo01的所有者,即window对象。
var foo02 = new function()
好像是定一个函数。但是实际上这是定一个JavaScript中的用户自定义对象,不过这里是个匿名类。这个用法和函数本身的使用基本没有任何关系,在大扩号中会构建一个变量作用域,this指代这个作用域本身。
var foo3 = new Function(...);
使用系统内置函数对象来构建一个函数,这和方法一中的第一种方式在效果和初始化优先级上都完全相同,就是函数体以字符串形式给出。
var foo4 = Function(..);
不过不清楚不用new来生成有没有什么副作用,这也体现了JavaScript一个最大的特性:灵活!能省就省。
#6
定义了一个对象?那这个对象叫什么?怎么来用它..
如果是动态生成一个function 那怎么不直接写function(){} 这样写,又为何呢?
谢谢解答一下,我脑子都想爆炸了。
如果是动态生成一个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
可以用旧的函数来创建一次性对象:
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
这个代码有点点出入哈,new function是生成一个类,而后者只是一个匿名函数,他们的this指的也不同,前者的this就是自身,而后者的this则指向了上层域。