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-世界上误解最深的语言分析
Aug 12 Javascript
Domino中运用jQuery读取视图内容的方法
Oct 21 Javascript
javascript正则表达式中的replace方法详解
Apr 20 Javascript
jQuery简单实现两级下拉菜单效果代码
Sep 15 Javascript
Javascript实现登录记住用户名和密码功能
Mar 22 Javascript
vue如何引用其他组件(css和js)
Apr 13 Javascript
jQuery实现web页面樱花坠落的特效
Jun 01 jQuery
vue2.0中vue-cli实现全选、单选计算总价格的实例代码
Jul 18 Javascript
vue列表单项展开收缩功能之this.$refs的详解
May 05 Javascript
基于layui轮播图满屏是高度自适应的解决方法
Sep 16 Javascript
基于Angular 8和Bootstrap 4实现动态主题切换的示例代码
Feb 11 Javascript
微信小程序文章详情功能完整实例
Jun 03 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实现读取和写入tab分割的文件
2015/06/01 PHP
php快速排序原理与实现方法分析
2016/05/26 PHP
PHP读取大文件末尾N行的高效方法推荐
2016/06/03 PHP
php自动载入类用法实例分析
2016/06/24 PHP
JavaScript(JS) 压缩 / 混淆 / 格式化 批处理工具
2010/12/10 Javascript
小结Node.js中非阻塞IO和事件循环
2014/09/18 Javascript
js兼容火狐显示上传图片预览效果的方法
2015/05/21 Javascript
javascript删除数组重复元素的方法汇总
2015/06/24 Javascript
jQuery实现网页顶部固定导航效果代码
2015/12/24 Javascript
JavaScript中的this,call,apply使用及区别详解
2016/01/29 Javascript
nodeJs爬虫获取数据简单实现代码
2016/03/29 NodeJs
深入理解ES6学习笔记之块级作用域绑定
2017/08/19 Javascript
javascript  删除select中的所有option的实例
2017/09/17 Javascript
Node.js创建Web、TCP服务器
2017/12/05 Javascript
webpack构建的详细流程探底
2018/01/08 Javascript
微信小程序功能之全屏滚动效果的实现代码
2018/11/22 Javascript
vue实现鼠标移入移出事件代码实例
2019/03/27 Javascript
vue Tab切换以及缓存页面处理的几种方式
2019/11/05 Javascript
Element Carousel 走马灯的具体实现
2020/07/26 Javascript
[02:40]DOTA2英雄基础教程 巨牙海民
2013/12/23 DOTA
[44:15]DOTA2上海特级锦标赛主赛事日 - 5 败者组决赛Liquid VS EG第二局
2016/03/06 DOTA
Python动态加载模块的3种方法
2014/11/22 Python
python从入门到精通(DAY 2)
2015/12/20 Python
python使用itchat实现手机控制电脑
2018/02/22 Python
Python实现在某个数组中查找一个值的算法示例
2018/06/27 Python
pycharm修改界面主题颜色的方法
2019/01/17 Python
用python实现英文字母和相应序数转换的方法
2019/09/18 Python
tensorflow的计算图总结
2020/01/12 Python
Python 列表推导式需要注意的地方
2020/10/23 Python
H5 video poster属性设置视频封面的方法
2020/05/25 HTML / CSS
Gap英国官网:Gap UK
2018/07/18 全球购物
尊师重教演讲稿
2014/09/04 职场文书
颐和园导游词400字
2015/01/30 职场文书
简单的辞职信怎么写
2015/02/28 职场文书
linux下导入、导出mysql数据库命令的实现方法
2021/05/26 MySQL
HttpClient实现文件上传功能
2022/08/14 Java/Android