function C(name){
this.name=name
}
var a=new C()
a instanceof C //true
C.prototype.isPrototypeOf(a) //true
Function.prototype.isPrototypeOf(C)
Object.prototype.isPrototypeOf(Function)
Object.prototype.isPrototypeOf(a) //true
构造函数
生成对象实例的模板,首字母大写来区别普通函数
特点:
- 函数体内部使用了this关键字,代表了所要生成的对象实例。
- 生成对象的时候,必需用new命令,调用Vehicle函数。
- 在new命令执行时,构造函数内部的this,就代表了新生成的实例对象
如果不使用new命令,而是在全局环境下运行了构造函数,this就会指向全局
function Person(name){this.name=name}
Person('wang')
name // 'wang'
new命令的原理
1. 创建一个空对象,作为要返回的对象实例
2. 把空对象的原型指向构造函数的prototype属性
3. 把空对象赋值给构造函数内部的this
4. 执行构造函数代码
特殊情况:
如果构造函数内部有return语句,而且return后面跟着一个对象,new命令会返回return语句指定的对象;否则,就会不管return语句,返回this对象。
prototype
- 每一个构造函数都有prototype属性,这个属性就是实例对象的原型
- JavaScript的所有对象都有构造函数,而所有构造函数都有prototype属性
- 原型本身也是对象,又有自己的原型
constructor属性
prototype对象有一个constructor属性,默认指向prototype对象所在的构造函数
function P() {}
P.prototype.constructor === P
// true
Object.getPrototypeOf()
获取某个对象的原型
function A(name){this.name=name}
var b=new A('wang')
Object.getPrototypeOf(b)===A.prototype //true
Object.create()
var o1 = { p: 1 };
var o2 = Object.create(o1);
//o1成了o2的原型
Object.getPrototypeOf(o2)===o1 //true