美文网首页
原型与原型链

原型与原型链

作者: wrs瑞 | 来源:发表于2019-10-08 11:34 被阅读0次
原型

每个构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针。

实例对象有个属性[prototype],叫做(__ proto__),实例对象可以通过这个属性访问原型对象上的属性和方法

var M = function (name) {
  this.name = name
}
var o = new M('o')
o.__proto__// 原型对象
原型链

假如我们让原型对象等于另一个类型的实例,此时的原型对象讲包含在一个指向另一个原型的指针,相应的,另一个原型中也包含着一个指向另一个构造函数的指针。这样层层递进,就狗证了实例与原型的链条,就是所谓的原型链。

var M = function (name) {
  this.name = name
}
var o = new M('o')
M.prototype.say=function(){
  console.log(this.name)
}
o.say(); // o
M.__proto__ === Function.prototype; // true
M.prototype.constructor === M; // true

原型链
function Parent() {
  this.name='parent';
  this.home='home';
}
function Child(){
  Parent.call(this)
  this.type = 'chile'
}
var child= new Child();
console.log(child.home); //home

上例中,Child类继承了Parent类,而child是Child类的一个实例,当我们想打印child.home时,首先在对象内部寻找该属性,直至找不到,然后才在该对象的原型(child.prototype)里去找这个属性,Child没有home属性,则从实例的child.proto(指向其构造函数Child.prototype对象)对象中查找,此时,Child中也没有次属性,就再向上一级child.proto.proto也就是Parent的原型对象上找,就找到了Parent上的home属性。

创建对象的方法
1.字面量 
var o1 = {name:'o1'} 
var o2 = new Object({name: 'o2'})
2.显示构造函数 
var M = function(name) {this.name = name}
var o3 = new M('o3')
3.Object.create
var p = {name:'p'}
var o4 = Object.create(p)
o4.__proto__ === p //true
instanceof原理
instanceof

instanceof 运算符用来判断实例对象的proto属性和构造函数的prototype是否是同一个引用。instanceof 主要的实现原理就是只要右边变量的 prototype 在左边变量的原型链上即可。

var M = function(name) {this.name = name}
var o5 = new M('o5')
o5 instanceof M; // true
o5 instanceof Object; // true
o5.__proto__ === M.prototype; // true
M.prototype.__proto__ === Object.prototype; // true
o5.__proto__.constructor === M; // true
o5.__proto__.constructor === Object; // false
// 用constructor 判断构造函数直接生成的实例对象更为严谨。
new一个对象的过程
function M(name) {
  this.name = name
  //return this
}
var m = new M('m1');
console.log(m.name);//m1

1.创建一个新对象
2.this 指向这个新对象
3.执行代码,即对 this 赋值
4.返回 this(若返回值不为对象时)

// 模拟new运算符的工作原理
var new2 = function(fun) {
    var o = Object.create(fun.prototype)
    var k = fun.call(o)
    if(typeof k === 'object') {
        return k;
    } else {
        return o;
    }
}
var o6 = new2(M)
o6.intanceof(M) //true
o6.__proto__.constructor === M //true

相关文章

  • JavaScript 原型、原型链与原型继承

    原型,原型链与原型继承 用自己的方式理解原型,原型链和原型继承 javascript——原型与原型链 JavaSc...

  • 2019-01-28

    原型与原型链

  • 廖雪峰JS小记

    (function(){})() 原型,原型链 浅谈Js原型的理解JS 原型与原型链终极详解 对象 对象:一种无序...

  • Javascript(三)之原型继承理解

    进阶路线 3 原型继承 3.1 优秀文章 最详尽的 JS 原型与原型链终极详解 一 最详尽的 JS 原型与原型链终...

  • JavaScript 面向对象第一篇

    1.原型链 ---- (实例对象与原型之间的连接 叫做原型链) 2. hasOwnproperty ----(看是...

  • 原型与原型链以及继承

    今天复习下原型与原型链的知识,以及记录新学的继承知识点。 知识点纲要 原型与原型链 es5与es6继承 什么是原型...

  • JavaScript深入理解this关键字(一)

    摘要 最近在公司需要做培训,我打算把JavaScript中的原型与原型链讲给大家。但我在梳理原型与原型链的时候发现...

  • js_继承及原型链等(四)

    js_继承及原型链等(三) 1. 继承 依赖于原型链来完成的继承 发生在对象与对象之间 原型链,如下: ==原型链...

  • 原型链&instanceof关键字

    1.原型链&instanceof关键字 简单说明 原型链 与 instanceof 作用原理 1.原型链 1...

  • 原型、原型链

    (什么是原型、原型链?有什么作用) JavaScirpt深入之从原型到原型链 图解 Javascript 原型链 ...

网友评论

      本文标题:原型与原型链

      本文链接:https://www.haomeiwen.com/subject/yizguctx.html