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弹出框的用法示例(2)
Aug 26 Javascript
jQuery中delegate和on的用法与区别详细解析
Jan 26 Javascript
JavaScript实现快速排序的方法
Jul 31 Javascript
拥有一个属于自己的javascript表单验证插件
Mar 24 Javascript
JavaScript中数组的22种方法必学(推荐)
Jul 20 Javascript
jQuery Ajax 异步加载显示等待效果代码分享
Aug 01 Javascript
简单实现jQuery多选框功能
Jan 09 Javascript
详解基于angular路由的requireJs按需加载js
Jan 20 Javascript
webstrom Debug 调试vue项目的方法步骤
Jul 17 Javascript
vue-cli3使用 DllPlugin 实现预编译提升构建速度
Apr 24 Javascript
微信小程序实现Swiper轮播图效果
Nov 22 Javascript
解决Vue大括号字符换行踩的坑
Nov 09 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
咖啡豆分级制度 咖啡豆等级分类 咖啡豆是按口感分类的吗?
2021/03/05 新手入门
PHP4实际应用经验篇(9)
2006/10/09 PHP
php获取网页内容方法总结
2008/12/04 PHP
在PHP中检查PHP文件是否有语法错误的方法
2009/12/23 PHP
php+mysql大量用户登录解决方案分析
2014/12/29 PHP
ThinkPHP、ZF2、Yaf、Laravel框架路由大比拼
2015/03/25 PHP
php实现与python进行socket通信的方法示例
2017/08/30 PHP
PHP实现的ID混淆算法类与用法示例
2018/08/10 PHP
Laravel5.1框架注册中间件的三种场景详解
2019/07/09 PHP
jquery ajax提交表单数据的两种方式
2009/11/24 Javascript
Web开发者必备的12款超赞jQuery插件
2010/12/03 Javascript
js获取location.href的参数实例代码
2013/08/02 Javascript
sencha ext js 6 快速入门(必看)
2016/06/01 Javascript
Wireshark基本介绍和学习TCP三次握手
2016/08/15 Javascript
纯js和css完成贪吃蛇小游戏demo
2016/09/01 Javascript
jQuery-mobile事件监听与用法详解
2016/11/23 Javascript
NodeJs使用Mysql模块实现事务处理实例
2017/05/31 NodeJs
JavaScript创建对象方法实例小结
2018/09/03 Javascript
Vue刷新修改页面中数据的方法
2018/09/16 Javascript
JS/HTML5游戏常用算法之路径搜索算法 A*寻路算法完整实例
2018/12/14 Javascript
JS数组方法reduce的用法实例分析
2020/03/03 Javascript
js函数和this用法实例分析
2020/03/13 Javascript
解决qrcode.js生成二维码时必须定义一个空div的问题
2020/07/09 Javascript
Python实现抓取百度搜索结果页的网站标题信息
2015/01/22 Python
Tensorflow卷积神经网络实例
2018/05/24 Python
一行Python代码制作动态二维码的实现
2019/09/09 Python
Jupyter notebook如何实现指定浏览器打开
2020/05/13 Python
Python图像阈值化处理及算法比对实例解析
2020/06/19 Python
如何编写python的daemon程序
2021/01/07 Python
酒店服务与管理毕业生求职信
2013/11/02 职场文书
群众路线批评与自我批评发言稿
2014/10/16 职场文书
抗洪救灾感谢信
2015/01/22 职场文书
欠款纠纷起诉状
2015/05/19 职场文书
大学文艺委员竞选稿
2015/11/19 职场文书
TypeScript 内置高级类型编程示例
2022/09/23 Javascript
蓝牙耳机怎么连接电脑win11? Win11蓝牙耳机连接电脑的技巧
2023/01/09 数码科技