prototype与__proto__区别详细介绍


Posted in Javascript onJanuary 09, 2017

prototype与__proto__区别

Each constructor is a function that has a property named “prototype” that is used to implement prototype-based inheritance and shared properties. Every object created by a constructor has an implicit reference (called the object's prototype) to the value of its constructor's “prototype” property.
When a constructor creates an object, that object implicitly references the constructor's prototype property for the purpose of resolving property references. The constructor's prototype property can be referenced by the program expression constructor.prototype, and properties added to an object's prototype are shared, through inheritance, by all objects sharing the prototype. Alternatively, a new object may be created with an explicitly specified prototype by using the Object.create built-in function. ?ECMAScript® 2015 Language Specification

__proto__是每个对象都有的一个属性,而prototype是函数才会有的属性!!!

使用Object.getPrototypeOf()代替__proto__!!!

一、prototype

几乎所有的函数(除了一些内建函数)都有一个名为prototype(原型)的属性,这个属性是一个指针,指向一个对象,而这个对象的用途是包含可以有特定类型的所有实例共享的属性和方法。prototype是通过调用构造函数而创建的那个对象实例的原型对象。hasOwnProperty()判断指定属性是否为自有属性;in操作符对原型属性和自有属性都返回true。

示例:自有属性&原型属性

var obj = {a: 1};
obj.hasOwnProperty("a"); // true
obj.hasOwnProperty("toString"); // false
"a" in obj; // true
"toString" in obj; // true

示例:鉴别原型属性

function hasPrototypeProperty(obj, name){
  return name in obj && !obj.hasOwnProperty(name);
}

二、__proto__

对象具有属性__proto__,可称为隐式原型,一个对象的隐式原型指向构造该对象的构造函数的原型,这也保证了实例能够访问在构造函数原型中定义的属性和方法。

function Foo(){}
var Boo = {name: "Boo"};
Foo.prototype = Boo;
var f = new Foo();

console.log(f.__proto__ === Foo.prototype); // true
console.log(f.__proto__ === Boo);  // true
Object.getPrototypeOf(f) === f.__proto__;  // true

三、Object.getPrototypeOf()

一个对象实例通过内部属性[[Prototype]]跟踪其原型对象。使用原型对象的好处是可以让所有对象实例共享它所包含的属性和方法。可以调用对象的Object.getPrototypeOf()方法读取[[Prototype]]属性的值,也可以使用isPrototypeOf()方法检查某个对象是否是另一个对象的原型对象。大部分JavaScript引擎在所有对象上都支持一个名为__proto__的属性,该属性可以直接读写[[Prototype]]属性。

示例:原型对象

function Person(name) {
  this.name = name;
}
Person.prototype = {
  constructor: Person,
  sayName: function(){
    console.log("my name is " + this.name);
  }
}
var p1 = new Person("ligang");
var p2 = new Person("Camile");
p1.sayName();  // my name is ligang
p2.sayName();  // my name is Camile

prototype与__proto__区别详细介绍

While Object.prototype.proto is supported today in most browsers, its existence and exact behavior has only been standardized in the ECMAScript 6 specification as a legacy feature to ensure compatibility for web browsers. For better support, it is recommended that only Object.getPrototypeOf() be used instead. ?MDN

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
js中访问html中iframe的文档对象的代码[IE6,IE7,IE8,FF]
Jan 08 Javascript
javascript中input中readonly和disabled区别介绍
Oct 23 Javascript
jQuery列表拖动排列具体实现
Nov 04 Javascript
JavaScript通过字符串调用函数的实现方法
Mar 18 Javascript
jQuery中 delegate使用的问题
Jul 03 Javascript
web前端开发JQuery常用实例代码片段(50个)
Aug 28 Javascript
使用jQuery制作遮罩层弹出效果的极简实例分享
May 12 Javascript
AngularJS ng-bind-template 指令详解
Jul 30 Javascript
用JS动态设置CSS样式常见方法小结(推荐)
Nov 10 Javascript
react router4+redux实现路由权限控制的方法
May 03 Javascript
Vue拖拽组件开发实例详解
May 11 Javascript
解决vue props 拿不到值的问题
Sep 11 Javascript
jQuery实现二维码扫描功能
Jan 09 #Javascript
详解Jquery 遍历数组之$().each方法与$.each()方法介绍
Jan 09 #Javascript
详解js产生对象的3种基本方式(工厂模式,构造函数模式,原型模式)
Jan 09 #Javascript
基于jQuery实现滚动刷新效果
Jan 09 #Javascript
用jQuery实现优酷首页轮播图
Jan 09 #Javascript
AngularJS实现表单验证功能
Jan 09 #Javascript
AngularJS表单基本操作
Jan 09 #Javascript
You might like
WHOIS类的修改版
2006/10/09 PHP
如何从一个php文件向另一个地址post数据,不用表单和隐藏的变量的
2007/03/06 PHP
24条货真价实的PHP代码优化技巧
2016/07/28 PHP
实用javaScript技术-屏蔽类
2006/08/15 Javascript
js获取单选按钮的数据
2006/11/27 Javascript
js异或加解密效果代码
2008/06/25 Javascript
jquery下操作HTML控件的实现代码
2010/01/12 Javascript
Javascript 鼠标移动上去小三角形滑块缓慢跟随效果
2013/04/26 Javascript
基于JQuery实现的图片自动进行缩放和裁剪处理
2014/01/31 Javascript
回车直接实现点击某按钮的效果即触发单击事件
2014/02/27 Javascript
JS实现从表格中动态删除指定行的方法
2015/03/31 Javascript
Node.js文件操作方法汇总
2016/03/22 Javascript
js实现select二级联动下拉菜单
2020/04/17 Javascript
使用jQuery调用XML实现无刷新即时聊天
2016/08/07 Javascript
jQuery自定义插件详解及实例代码
2016/12/29 Javascript
快速解决vue-cli不能初始化webpack模板的问题
2018/03/20 Javascript
微信小程序中的canvas 文字断行和省略号显示功能的处理方法
2018/11/14 Javascript
浅谈Vuex注入Vue生命周期的过程
2019/05/20 Javascript
vue.js实现三级菜单效果
2019/10/19 Javascript
[01:20]DOTA2更新全新英雄 天涯墨客现已加入游戏
2018/08/25 DOTA
[51:39]DOTA2-DPC中国联赛 正赛 Magma vs LBZS BO3 第二场 2月7日
2021/03/11 DOTA
判断网页编码的方法python版
2016/08/12 Python
Python中struct模块对字节流/二进制流的操作教程
2017/01/21 Python
Python判断对象是否相等及eq函数的讲解
2019/02/25 Python
Django多数据库配置及逆向生成model教程
2020/03/28 Python
详解CSS3中使用gradient实现渐变效果的方法
2015/08/18 HTML / CSS
.NET程序员的几道面试题
2012/06/01 面试题
大学生简单自荐信
2013/11/10 职场文书
优秀毕业大学生推荐信
2013/11/13 职场文书
农业资源与环境专业自荐信范文
2013/12/30 职场文书
社团招新策划书
2014/02/04 职场文书
2014年元旦联欢会活动策划方案
2014/02/16 职场文书
2016公司中秋节寄语
2015/12/07 职场文书
教你用Python写一个植物大战僵尸小游戏
2021/04/25 Python
MySql数据库 查询时间序列间隔
2022/05/11 MySQL
MySQL实现用逗号进行拼接、以逗号进行分割
2022/12/24 MySQL