JavaScript三大毒瘤 ——— this,原型链,作用域

在我等菜鸟一步一步升级中的过程中,这三个概念总是困扰这我们(可能只有我吧,我比较蠢)。这三个东西往往都很绕,今天我就来分享一下我对原型、原型链的理解,希望各路大神看到我有错的能纠正一下,也希望能帮助到不懂的人,能逐渐把这些弄懂。

首先 要弄清楚 原型链 ,首先要知道这三个东西 prototype  [[Prototype]]  constructor 。哇 这都是什么鬼啊? 好,现在我们就详细说说这三者分别是什么东西。

prototype(原型)

我们创建的每一个 构造函数 都有一个 prototype 属性,这属性是一个 指针 ,指向一个 对象

这个对象就是我们用 new构造函数 创建的那个 对象实例 相对应继承的 原型对象,即指向自身的对象。 

可能这个不太好理解 那我们就写个例子理解一下。

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
</head>
<body>
</body>
</html>
<script>
function Person(name,gender){ // 这个就是原型,也是一个构造函数,首字母大写
this.name = name;
this.gender = gender;
}
Person.prototype.eat = "哇,贼好吃."; // 在prototype写的方法,继承他的都能使用到 var person1 = new Person("MIse","male"); // 这个就是 对象实例 他的原型就是 Person 这个构造函数 console.log(person1.name); // MIse
console.log(person1.gender); // male
console.log(person1.eat); // 哇,贼好吃. </script>

在这个例子里,Person 就是 person1 的原型 , person1 可以继承到 Person 上面 eat 的方法。

所以这个prototype的主要作用就是 将一些方法或不变的属性 写在prototype上面,从而由这个 原型对象 所创造出来的 对象实例 可以 共享他所有的方法和属性

这样写的好处就是,不用在构造函数里面定义对象实例的信息,而是可以将这些信息直接添加到原型对象中。而且节省内存,把方法存在 堆内存 中,栈内存 只存放指向这个方法的指针。

简单得科普一下 堆栈。

Javascript 分两种 基本类型引用类型

  • 基本类型 (Undefined、Null、Boolean、Number和String)

基本类型在内存中占据空间小、大小固定 ,他们的值保存在栈(stack)空间,是按值来访问

  • 引用类型 (对象、数组、函数)

引用类型占据空间大、大小不固定, 栈内存中存放地址指向堆(heap)内存中的对象。是按引用访问的

[[Prototype]] (实例内部的一个属性)

每一个 构造函数创建的 对象实例 都有一个[[Prototype]]属性。在JavaScript中,因为[[Prototype]]没有标准的访问方式,所以通常这个属性都是通过__proto__来代替访问

每个 对象实例 都有一个 __proto__ 属性,这属性也是一个 指针 ,这个指针也是指向一个 对象

这个对象就是 创建它这对象实例本身的原型对象,这个就是存在于实例与构造函数的原型对象之间的连接

这也是为什么 person1 能够访问到 Person 的方法的原因。因为 person1(对象实例)是继承于 Person(原型对象)

constructor(构造函数) 

每一个 构造函数 内部都会有一个 constructor 的属性,这个属性也是一个 指针,指向该prototype属性所在函数的指针

他的作用也就是 往这个原型 添加更多的方法或属性。

三者的关系

简单来说呢。就是。

person1.__proto__ === Person.prototype

person1.prototype.constructor 会报错

Person.prototype.constructor === Person

Person.proto === Function.prototype

Person.prototype.__proto__ === Object.prototype    因为所有函数都是由Object继承过来的

Object.prototype.proto === null

Object.proto === Function.prototype

最后

个人建议大家还是静下心来看一下这个关系图。顺着关系看多几次。一次不懂看多几次。总有一次会恍然开朗的!

因为我也是初学者。希望有写错的大家能提醒我一下,共同交流进步。谢谢!

Javascript Prototype __proto__ constructor 三者的关系的更多相关文章

  1. 简述prototype, _proto_, constructor三者的关系

    1.prototype 感概:每个函数都有一个prototype这个属性,而这个属性指向一个对象,这个对象称为原型对象 作用: a.节约内存 b.扩展属性和方法 c.实现类与类的之间的继承 2._pr ...

  2. 关于 JavaScript prototype __proto__ 一点总结

    http://www.cnblogs.com/wbin91/p/5265163.html 先上代码 function(y) Foo{ this.y = y;} Foo.prototype.x = 10 ...

  3. javascript prototype __proto__区别

    An Object's __proto__ property references the same object as its internal [[Prototype]] (often refer ...

  4. js in depth: Object & Function & prototype & __proto__ & constructor & classes inherit

    js in depth: Object & Function & prototype & proto & constructor & classes inher ...

  5. prototype,__proto__,constructor

    proto属性: 所有对象都有此属性.但它不是规范里定义的属性,并不是所有JavaScript运行环境都支持.它指向对象的原型,也就是你说的继承链里的原型.通过Object.getPrototypeO ...

  6. 实践一些js中的prototype, __proto__, constructor

    <!DOCTYPE html> <html> <head> <title>ExtJs</title> <meta http-equiv ...

  7. Prototype and Constructor in JavaScript

    The concept of prototype in JavaScript is very confusing, especially to those who come with a C++/JA ...

  8. illustrating javascript prototype & prototype chain

    illustrating javascript prototype & prototype chain 图解 js 原型和原型链 proto & prototype func; // ...

  9. javascript中prototype、constructor以及__proto__之间的三角关系

    三者暧昧关系简单整理 在javascript中,prototype.constructor以及__proto__之间有着“著名”的剪不断理还乱的三角关系,楼主就着自己对它们的浅显认识,来粗略地理理以备 ...

随机推荐

  1. js的event事件

    一 .  焦点:使浏览器能够区分区分用户输入的对象,当一个元素有焦点的时候,那么他就可以接收用户的输入. 我们可以通过一些方式给元素设置焦点 1.点击 2.tab   3.js 不是所有元素都能够接受 ...

  2. HTML5笔记3——Web Storage和本地数据库

    上一篇:HTML5笔记2——HTML5音/视频标签详解 Web Storage概述 在HTML5中,除了Canvas元素之外,另一个新增的非常重要的功能是可以再客户端本地保存数据的Web Storag ...

  3. 【MyBatis源码分析】insert方法、update方法、delete方法处理流程(下篇)

    Configuration的newStatementHandler分析 SimpleExecutor的doUpdate方法上文有分析过: public int doUpdate(MappedState ...

  4. Coursera 机器学习笔记(一)

    主要是第一二周内容 机器学习概要 机器学习是什么? 生活在信息时代的我们,其实时时刻刻都离不开机器学习算法.比如日常使用的搜索引擎就涉及到很多学习算法. Arthur Samuel 给出第一个定义.他 ...

  5. String、StringBuffer、StringBuilder比较

    String.StringBuffer.StringBuilder三者是字符串中重要的内容,也是面试过程中经常问到的问题,下面就来总结一下三者的区别. 1.三者都可以存储和操作字符串. 2.Strin ...

  6. Hybrid App开发之jQuery基础

    前言: 前面学习了JavaScript/Html/Css的基础知识,今天学习一下常用js框架jQuery的使用进行快速的开发. JQuery的基本功能: 方位和操作DOM元素 控制页面样式 对页面事件 ...

  7. 允许mysql用户从远程登录

    1.修改/etc/mysql/my.cnf,将下面的行注释掉bind=127.0.0.1注释#bind=127.0.0.1 2.修改用户权限,允许从任何主机登录mysql>use mysql;m ...

  8. ORA-00245问题总结

    (1)问题描述 在进行数据库归档备份时(备份归档日志文件和控制文件),有时成功,有时失败,失败报错如下: RMAN-00571: =================================== ...

  9. WindowManager.LayoutParams的探究

    上次在子线程更新UI时用了一下WindowManager.LayoutParams,当时觉得不太顺手.以前都是用空参构造器,这次用了type和flag属性,出现了意想不到的效果.也看看源码吧,多锻炼锻 ...

  10. java高并发锁的3种实现

    初级技巧 - 乐观锁 乐观锁适合这样的场景:读不会冲突,写会冲突.同时读的频率远大于写. 以下面的代码为例,悲观锁的实现: Java代码   public Object get(Object key) ...