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 相关文章推荐
jquery 实现checkbox全选,反选,全不选等功能代码(奇数)
Oct 24 Javascript
js操作输入框中选择内容兼容IE及其他主流浏览器
Apr 22 Javascript
node.js中RPC(远程过程调用)的实现原理介绍
Dec 05 Javascript
jQuery Validate验证框架详解(推荐)
Dec 17 Javascript
深入理解vue-loader如何使用
Jun 06 Javascript
vue子父组件通信的实现代码
Jul 09 Javascript
详解从新建vue项目到引入组件Element的方法
Aug 29 Javascript
jQuery简单实现的HTML页面文本框模糊匹配查询功能完整示例
May 09 jQuery
Vue中div contenteditable 的光标定位方法
Aug 25 Javascript
vue.js单文件组件中非父子组件的传值实例
Sep 13 Javascript
vue和better-scroll实现列表左右联动效果详解
Apr 29 Javascript
vue中重定向redirect:‘/index‘,不显示问题、跳转出错的完美解决
Sep 28 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
声音就能俘获人心,蕾姆,是哪个漂亮小姐姐配音呢?
2020/03/03 日漫
destoon实现会员商铺中指定会员或会员组投放广告的方法
2014/08/21 PHP
PHP数学运算函数大汇总(经典值得收藏)
2016/04/01 PHP
PHP中file_exists使用中遇到的问题小结
2016/04/05 PHP
Symfony2针对输入时间进行查询的方法分析
2017/06/28 PHP
Laravel学习基础之migrate的使用教程
2017/10/11 PHP
详解使用php-cs-fixer格式化代码
2020/09/16 PHP
js中return false(阻止)的用法
2013/08/14 Javascript
JavaScript动态创建link标签到head里的方法
2014/12/22 Javascript
javascript拖拽应用实例(二)
2016/03/25 Javascript
jquery对Json的各种遍历方法总结(必看篇)
2016/09/29 Javascript
基于cookie实现zTree树刷新后展开状态不变
2017/02/28 Javascript
underscore之Collections_动力节点Java学院整理
2017/07/10 Javascript
基于vue.js的分页插件详解
2017/11/27 Javascript
详解如何在nuxt中添加proxyTable代理
2018/08/10 Javascript
JS实现的获取银行卡号归属地及银行卡类型操作示例
2019/01/08 Javascript
深入分析jQuery.one() 函数
2020/06/03 jQuery
vue@cli3项目模板怎么使用public目录下的静态文件
2020/07/07 Javascript
JavaScript动画实例之粒子文本的实现方法详解
2020/07/28 Javascript
Vue数组响应式操作及高阶函数使用代码详解
2020/08/01 Javascript
[14:57]DOTA2 HEROS教学视频教你分分钟做大人-幽鬼
2014/06/13 DOTA
python中requests和https使用简单示例
2018/01/18 Python
Python中%是什么意思?python中百分号如何使用?
2018/03/20 Python
Python实现微信翻译机器人的方法
2019/08/13 Python
Python实现点云投影到平面显示
2020/01/18 Python
Biblibili视频投稿接口分析并以Python实现自动投稿功能
2021/02/05 Python
HTML5 对各个标签的定义与规定:body的介绍
2012/06/21 HTML / CSS
珍惜资源保护环境的建议书
2014/05/14 职场文书
大学课外活动总结
2014/07/09 职场文书
大班下学期幼儿评语
2014/12/30 职场文书
运动会入场词
2015/07/18 职场文书
劳务派遣管理制度(样本)
2019/08/23 职场文书
用JS创建一个录屏功能
2021/11/11 Javascript
动视暴雪取消疫苗禁令 让所有员工返回线下工作
2022/04/03 其他游戏
MySQL数据库配置信息查看与修改方法详解
2022/06/25 MySQL
HTML中link标签属性的具体用法
2023/05/07 HTML / CSS