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 相关文章推荐
JavaScript改变HTML元素的样式改变CSS及元素属性
Nov 12 Javascript
jQuery 鼠标经过(hover)事件的延时处理示例
Apr 14 Javascript
jQuery学习笔记之 Ajax操作篇(三) - 过程处理
Jun 23 Javascript
js和jquery中循环的退出和继续下一个循环
Sep 03 Javascript
node.js超时timeout详解
Nov 26 Javascript
JS交换变量的方法
Jan 21 Javascript
详谈构造函数加括号与不加括号的区别
Oct 26 Javascript
使用vuex缓存数据并优化自己的vuex-cache
May 30 Javascript
用Node提供静态文件服务的方法
Jul 06 Javascript
vue 点击展开显示更多(点击收起部分隐藏)
Apr 09 Javascript
vue 中几种传值方法(3种)
Nov 12 Javascript
Vue h函数的使用详解
Feb 18 Vue.js
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
苏联队长,苏联超人蝙蝠侠,这些登场的“山寨”英雄真的很严肃
2020/04/09 欧美动漫
PHP开发负载均衡指南
2010/07/17 PHP
php设计模式之命令模式的应用详解
2013/05/21 PHP
php实现简单洗牌算法
2013/06/18 PHP
PHP中提问频率最高的11个面试题和答案
2014/09/02 PHP
php中实现记住密码下次自动登录的例子
2014/11/06 PHP
yii添删改查实例
2015/11/16 PHP
PHP获取IP地址所在地信息的实例(使用纯真IP数据库qqwry.dat)
2016/11/15 PHP
yii框架使用分页的方法分析
2019/07/25 PHP
php探针不显示内存解决方法
2019/09/17 PHP
基于jQuery的动态增删改查表格信息,可左键/右键提示(原创自Zjmainstay)
2012/07/31 Javascript
js实现倒计时(距离结束还有)示例代码
2013/07/24 Javascript
鼠标移入移出事件改变图片的分辨率的两种方法
2013/12/17 Javascript
在JavaScript的AngularJS库中进行单元测试的方法
2015/06/23 Javascript
JavaScript中实现键值对应的字典与哈希表结构的示例
2016/06/12 Javascript
JQuery中Ajax的操作完整例子
2017/03/07 Javascript
JavaScript中的工厂函数(推荐)
2017/03/08 Javascript
jQuery插件HighCharts绘制2D柱状图、折线图和饼图的组合图效果示例【附demo源码下载】
2017/03/09 Javascript
jQuery插件HighCharts实现气泡图效果示例【附demo源码】
2017/03/13 Javascript
详解js跨域请求的两种方式,支持post请求
2018/05/05 Javascript
angularJs提交文本框数据到后台的方法
2018/10/08 Javascript
Vue.js组件高级特性实例详解
2018/12/24 Javascript
JS实现根据数组对象的某一属性排序操作示例
2019/01/14 Javascript
微信小程序实现转盘抽奖
2020/09/21 Javascript
python将人民币转换大写的脚本代码
2013/02/10 Python
Python中matplotlib中文乱码解决办法
2017/05/12 Python
Flask框架学习笔记之模板操作实例详解
2019/08/15 Python
python模拟实现分发扑克牌
2020/04/22 Python
python中数字是否为可变类型
2020/07/08 Python
aec加密 php_php aes加密解密类(兼容php5、php7)
2021/03/14 PHP
校园报刊亭的创业计划书
2014/01/02 职场文书
家长会演讲稿
2014/04/26 职场文书
5.12护士节演讲稿
2014/04/30 职场文书
教师党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
培训督导岗位职责
2015/04/10 职场文书
爱国主义教育基地观后感
2015/06/18 职场文书