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 相关文章推荐
Uglifyjs(JS代码优化工具)入门 安装使用
Apr 13 Javascript
用javascript删除当前行,添加行(示例代码)
Nov 25 Javascript
JS 数字转换研究总结
Dec 26 Javascript
JS的encodeURI和java的URLDecoder.decode使用介绍
May 08 Javascript
javascript制作游戏开发碰撞检测的封装代码
Mar 31 Javascript
非常酷炫的Bootstrap图片轮播动画
May 27 Javascript
轻松搞定js表单验证
Oct 13 Javascript
JS实现的驼峰式和连字符式转换功能分析
Dec 21 Javascript
JQuery validate 验证一个单独的表单元素实例
Feb 17 Javascript
深入理解Webpack 中路径的配置
Jun 17 Javascript
详解JavaScript的BUG和错误
May 07 Javascript
js循环map 获取所有的key和value的实现代码(json)
May 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
php启用zlib压缩文件的配置方法
2013/06/12 PHP
基于PHP输出缓存(output_buffering)的深入理解
2013/06/13 PHP
PHP register_shutdown_function()函数的使用示例
2015/06/23 PHP
PHP使用preg_split和explode分割textarea存放内容的方法分析
2017/07/03 PHP
yii2学习教程之5种内置行为类详解
2017/08/03 PHP
js 解决“options为空或不是对象”
2008/12/22 Javascript
JavaScript 类的定义和引用 JavaScript高级培训 自定义对象
2010/04/27 Javascript
jQueryPad 实用的jQuery测试工具(支持IE,chrome,FF)
2010/05/22 Javascript
Node.js中 __dirname 的使用介绍
2017/06/19 Javascript
微信小程序自定义导航教程(兼容各种手机)
2018/12/12 Javascript
JS对象和字符串之间互换操作实例分析
2019/02/02 Javascript
微信小程序实现折线图的示例代码
2019/06/07 Javascript
Vue组件简易模拟实现购物车
2020/12/21 Vue.js
js用正则表达式筛选年月日的实例方法
2021/01/04 Javascript
Python的SQLAlchemy框架使用入门
2015/04/29 Python
python实现杨辉三角思路
2017/07/14 Python
python+mongodb数据抓取详细介绍
2017/10/25 Python
对numpy.append()里的axis的用法详解
2018/06/28 Python
python实现简单名片管理系统
2018/11/30 Python
selenium python 实现基本自动化测试的示例代码
2019/02/25 Python
GitHub 热门:Python 算法大全,Star 超过 2 万
2019/04/29 Python
Python 多个图同时在不同窗口显示的实现方法
2019/07/07 Python
解决django model修改添加字段报错的问题
2019/11/18 Python
python中@contextmanager实例用法
2021/02/07 Python
html5中valid、invalid、required的定义
2014/02/21 HTML / CSS
英国足球店:UK Soccer Shop
2017/11/19 全球购物
好邻里事迹材料
2014/01/16 职场文书
先进集体获奖感言
2014/02/13 职场文书
企业承诺书格式
2014/05/21 职场文书
班级体育活动总结
2014/07/05 职场文书
领导班子遵守党的政治纪律情况对照检查材料
2014/09/26 职场文书
2015年网络舆情工作总结
2015/07/24 职场文书
工作一年自我鉴定
2019/06/20 职场文书
JS继承最简单的理解方式
2021/03/31 Javascript
对PyTorch中inplace字段的全面理解
2021/05/22 Python
Python 循环读取数据内存不足的解决方案
2021/05/25 Python