javaScript 原型对象与原型链

来源:互联网 发布:linux mv 文件夹 覆盖 编辑:程序博客网 时间:2024/05/21 15:04

一、prototype和__proto__的区别

这里写图片描述

__ proto __ 一般理解为类似 构造器原型

//函数对象var o = function () {    console.log(1)}o.constructor;//构造器 由constructor函数产生的o.constructor.prototype;//构造器原型//一般字面量对象var oo = {a: 1, b: 2}oo.constructor;//构造器 由constructor函数产生的oo.constructor.prototype;//构造器原型

这里写图片描述

__ proto __ 属性指向谁

这里写图片描述

/*1、字面量方式*/var a = {};console.log(a.__proto__);  //Object {}console.log(a.__proto__ === a.constructor.prototype); //true/*2、构造器方式*/var A = function(){};var a = new A();console.log(a.__proto__); //A {}console.log(a.__proto__ === a.constructor.prototype); //true/*3、Object.create()方式*/var a1 = {a:1}var a2 = Object.create(a1);console.log(a2.__proto__); //Object {a: 1}console.log(a.__proto__ === a.constructor.prototype); //false(此处即为图1中的例外情况)

什么是原型链

这里写图片描述

这里写图片描述

原创粉丝点击