面向对象编程

2017-06-30  本文已影响0人  chengfengwang
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

构造函数

生成对象实例的模板,首字母大写来区别普通函数
特点:

  1. 函数体内部使用了this关键字,代表了所要生成的对象实例。
  2. 生成对象的时候,必需用new命令,调用Vehicle函数。
  3. 在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

  1. 每一个构造函数都有prototype属性,这个属性就是实例对象的原型
  2. JavaScript的所有对象都有构造函数,而所有构造函数都有prototype属性
  3. 原型本身也是对象,又有自己的原型

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
上一篇下一篇

猜你喜欢

热点阅读