
你的写法只是普通函数的写法,但你要他用new构造对象,那内部属性要加上this,来动态绑定生成的对象,而你目前写法,只能说是A函数的私有变量,是不会通过new传出来的,所以只需要把你的内部函数变成 this.a=function(){}这种对象属性的样式才能正确的的通过new 生成你需要的对象~!
function A(){
var p=1
var q
this.A=function (x){
q=2
alert(x+p)
}
this.B=function (x){
alert(p+q+x)
}
}
var a=new A()
a.A(5)
a.B(6)
Object.prototype.write = function(){
alert('suc')
}
var ele=document.getElementById('text')
ele.write()
一、从定义的角度来说:
function Function(){}
前者为定义一个js函数
后者为这个函数的名称
Object为选择的DOM对象
二、从用法讲:
var a = new Object(function(){})
这里a也是function了。
三、总结:
不管是function ,还是new Function(), 还是new Object(function(){}),当解释器(例如V8)遇到时,则将它们初始化成一个函数(最主要的是给其添加了一个[[call]]属性)。
javascript中,“函数”(方法)也是对象。
一切对象都有一个根源。它是Object.prototype。
根源之上再没有其他根源。Object.getPrototypeOf(Object.prototype)是null。js中除字面量以外的一切引用对象都来自这个“根源”对象。
表达式Object.getPrototypeOf(Function) === Function.prototype的结果是真。这是Function特有的。实际上Function的prototype是一个内置函数,一切函数都派生自这个内置函数,这个内置函数是一个函数工厂。这个内置函数对象的prototype指向“根源”对象。
表达式Object.prototype === Object.getPrototypeOf(Function.prototype)的结果是真。说明了Object跟Function二者之间的联系,是通过“根源”对象联系起来的。
Function和Object,既是函数,因为都可以Function()或者Object()这样的方式执行,又是对象,因为可以Function.a = 'a',Object.a = 'a'这样赋值。
说它们是函数,是因为他们都是通过上面第4条中说的”内置函数工厂“,派生出来的,因而具备函数的特性。
说他们是对象。是因为他们都是通过上面第1条中的”根源“对象,派生出来的,因此具备对象的特征。
继续说一下,Function.prototype指向”内置函数“。而Object.prototype指向”根源对象“。
因而new Function会产生一个匿名函数,而new Object产生一个plain object。
他们之间的关系简单描述就像下面这样。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)