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实现加入收藏夹的代码
Oct 24 Javascript
解决extjs grid 不随窗口大小自适应的改变问题
Jan 26 Javascript
javascript实现微信分享
Dec 23 Javascript
JavaScript实现删除,移动和复制文件的方法
Aug 05 Javascript
JavaScript记录光标在编辑器中位置的实现方法
Apr 22 Javascript
jquery中用函数来设置css样式
Dec 22 Javascript
jQuery Ajax实现跨域请求
Jan 21 Javascript
jquery中$.fn和图片滚动效果实现的必备知识总结
Apr 21 jQuery
js canvas实现QQ拨打电话特效
May 10 Javascript
JavaScript实现单英文金山打字通
Jul 24 Javascript
angularjs模态框的使用代码实例
Dec 20 Javascript
react合成事件与原生事件的相关理解
May 13 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
PHP实现新型冠状病毒疫情实时图的实例
2020/02/04 PHP
合并table相同单元格的jquery插件分享(很精简)
2011/06/20 Javascript
解析JavaScript的ES6版本中的解构赋值
2015/07/28 Javascript
JS实现的车标图片提示效果代码
2015/10/10 Javascript
jQuery实现的右下角广告窗体跟随效果示例
2016/09/16 Javascript
Javascript ES6中对象类型Sets的介绍与使用详解
2017/07/17 Javascript
基于ES6作用域和解构赋值详解
2017/11/03 Javascript
ReactNative中使用Redux架构总结
2017/12/15 Javascript
AngularJS使用ui-route实现多层嵌套路由的示例
2018/01/10 Javascript
layui弹出层按钮提交iframe表单的方法
2018/08/20 Javascript
浅谈vue项目4rs vue-router上线后history模式遇到的坑
2018/09/27 Javascript
vue.js循环radio的实例
2019/11/07 Javascript
微信小程序个人中心的列表控件实现代码
2020/04/26 Javascript
解决Vue的项目使用Element ui 走马灯无法实现的问题
2020/08/03 Javascript
JavaScript实现拖动对话框效果的实现代码
2020/10/12 Javascript
[00:53]2015国际邀请赛 中国区预选赛一触即发
2015/05/14 DOTA
[40:55]Liquid vs LGD 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
Python 正则表达式操作指南
2009/05/04 Python
简单说明Python中的装饰器的用法
2015/04/24 Python
Pycharm更换python解释器的方法
2018/10/29 Python
Empty test suite.(PyCharm程序运行错误的解决方法)
2018/11/30 Python
Python matplotlib画图与中文设置操作实例分析
2019/04/23 Python
python使用wxpy实现微信消息防撤回脚本
2019/04/29 Python
为什么你还不懂得怎么使用Python协程
2019/05/13 Python
python实时检测键盘输入函数的示例
2019/07/17 Python
Python完成哈夫曼树编码过程及原理详解
2019/07/29 Python
python虚拟环境的安装和配置(virtualenv,virtualenvwrapper)
2019/08/09 Python
windows中安装Python3.8.0的实现方法
2019/11/19 Python
K最近邻算法(KNN)---sklearn+python实现方式
2020/02/24 Python
解决django FileFIELD的编码问题
2020/03/30 Python
Django crontab定时任务模块操作方法解析
2020/09/10 Python
Python从MySQL数据库中面抽取试题,生成试卷
2021/01/14 Python
CSS图片翻转动画技术详解(IE也实现了)
2014/04/03 HTML / CSS
社会实践自我鉴定
2013/11/07 职场文书
中考学习决心书
2015/02/04 职场文书
2019自荐信范文集锦!
2019/07/03 职场文书