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 EasyUI 开源插件套装 完全替代ExtJS
Mar 24 Javascript
简单的代码实现jquery定时器
Jan 03 Javascript
JavaScript中的replace()方法使用详解
Jun 06 Javascript
JavaScript编程中window的location与history对象详解
Oct 26 Javascript
jQuery实现带玻璃流光质感的手风琴特效
Nov 20 Javascript
详解JavaScript的表达式与运算符
Nov 30 Javascript
Angular.js与Bootstrap相结合实现手风琴菜单代码
Apr 13 Javascript
15款最好的Bootstrap在线编辑器
Aug 03 Javascript
详解基于javascript实现的苹果系统底部菜单
Dec 02 Javascript
关于angular js_$watch监控属性和对象详解
Apr 24 Javascript
Vue页面跳转动画效果的实现方法
Sep 23 Javascript
AngularJS实现多级下拉框
Mar 25 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 数字左侧自动补0
2008/03/31 PHP
在PHP中使用模板的方法
2008/05/24 PHP
PHP常用数组函数介绍
2014/07/28 PHP
ThinkPHP独立分组使用的注意事项
2014/11/25 PHP
4种PHP异步执行的常用方式
2015/12/24 PHP
PHP面向对象五大原则之单一职责原则(SRP)详解
2018/04/04 PHP
php实现小程序支付完整版
2018/10/09 PHP
Yii框架自定义数据库操作组件示例
2019/11/11 PHP
在线编辑器中换行与内容自动提取
2009/04/24 Javascript
给超链接添加特效鼠标移动展示提示信息且随鼠标移动
2013/10/17 Javascript
深入理解javascript动态插入技术
2013/11/12 Javascript
Extjs4实现两个GridPanel之间数据拖拽功能具体方法
2013/11/21 Javascript
老司机带你解读jQuery插件开发流程
2016/05/16 Javascript
简单封装js的dom查询实例代码
2016/07/08 Javascript
js模态对话框使用方法详解
2017/02/16 Javascript
js实现二级导航功能
2017/03/03 Javascript
JavaScript使用原型和原型链实现对象继承的方法详解
2017/04/05 Javascript
Echarts基本用法_动力节点Java学院整理
2017/08/11 Javascript
使用watch监听路由变化和watch监听对象的实例
2018/02/24 Javascript
Vuex入门到上手教程
2018/06/20 Javascript
angular-tree-component的使用详解
2018/07/30 Javascript
vue项目持久化存储数据的实现代码
2018/10/01 Javascript
video.js 一个页面同时播放多个视频的实例代码
2018/11/27 Javascript
使用konva和vue-konva库实现拖拽滑块验证功能
2020/04/27 Javascript
vue-cli3项目配置eslint代码规范的完整步骤
2020/09/10 Javascript
Python爬取附近餐馆信息代码示例
2017/12/09 Python
Python去除、替换字符串空格的处理方法
2018/04/01 Python
解决Django 在ForeignKey中出现 non-nullable field错误的问题
2019/08/06 Python
解决Keras中CNN输入维度报错问题
2020/06/29 Python
html5中监听canvas内部元素点击事件的三种方法
2019/04/28 HTML / CSS
与C++相比,Java中的数组有什么不同
2014/03/25 面试题
理货员的岗位职责
2013/11/23 职场文书
《守株待兔》教学反思
2014/03/01 职场文书
2014县政府领导班子对照检查材料思想汇报
2014/09/25 职场文书
党的群众路线教育实践活动学习笔记范文
2014/11/06 职场文书
复制别人的成功真的会成功吗?
2019/10/17 职场文书