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 相关文章推荐
禁止js文件缓存的代码
Apr 09 Javascript
利用JS自动打开页面上链接的实现代码
Sep 25 Javascript
javascript简单事件处理和with用法介绍
Sep 16 Javascript
在javascript中如何得到中英文混合字符串的长度
Jan 17 Javascript
javascript中定义类的方法汇总
Dec 28 Javascript
flash+jQuery实现可关闭及重复播放的压顶广告
Apr 15 Javascript
JavaScript函数使用的基本教程
Jun 04 Javascript
jQuery中ajax的load()与post()方法实例详解
Jan 05 Javascript
JS搜狐面试题分析
Dec 16 Javascript
解决VUEX刷新的时候出现数据消失
Jul 03 Javascript
JS数组求和的常用方法总结【5种方法】
Jan 14 Javascript
解决node.js含有%百分号时发送get请求时浏览器地址自动编码的问题
Nov 20 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
Fedora下安装php Redis扩展笔记
2014/09/03 PHP
微信API接口大全
2015/04/15 PHP
PHP使用DOM对XML解析处理操作示例
2019/07/04 PHP
PHP实现发送微博消息功能完整示例
2019/12/04 PHP
javascript 定义新对象方法
2010/02/20 Javascript
鼠标经过显示二级菜单js特效
2013/08/13 Javascript
jQuery html()方法使用不了无法显示内容的问题
2014/08/06 Javascript
不同编码的页面表单数据乱码问题解决方法
2015/02/15 Javascript
javascript实现漂亮的拖动层,窗口拖拽特效
2015/04/24 Javascript
animate 实现滑动切换效果【实例代码】
2016/05/05 Javascript
javascript获取select标签选中的值
2016/06/04 Javascript
js中的关联数组与普通数组详解
2016/07/27 Javascript
微信小程序 倒计时组件实现代码
2016/10/24 Javascript
javascript鼠标跟随运动3种效果(眼球效果,苹果菜单,方向跟随)
2016/10/27 Javascript
详解Angularjs在控制器(controller.js)中使用过滤器($filter)格式化日期/时间实例
2017/02/17 Javascript
javascript数组去重常用方法实例分析
2017/04/11 Javascript
Angular-UI Bootstrap组件实现警报功能
2018/07/16 Javascript
vue-cli2打包前和打包后的css前缀不一致的问题解决
2018/08/24 Javascript
Nuxt.js实现校验访问浏览器类型的中间件
2018/08/24 Javascript
解决Vue+Element ui开发中碰到的IE问题
2018/09/03 Javascript
Vue组件Draggable实现拖拽功能
2018/12/01 Javascript
浅谈Fetch 数据交互方式
2018/12/20 Javascript
在JavaScript中使用严格模式(Strict Mode)
2019/06/13 Javascript
JS实现的定时器展示简单秒表、页面弹框及跳转操作完整示例
2020/01/26 Javascript
vue引用外部JS的两种种方法
2020/01/28 Javascript
vue3.0+vue-router+element-plus初实践
2020/12/02 Vue.js
Python使用matplotlib实现的图像读取、切割裁剪功能示例
2018/04/28 Python
Numpy的简单用法小结
2019/08/28 Python
pycharm 中mark directory as exclude的用法详解
2020/02/14 Python
python实现程序重启和系统重启方式
2020/04/16 Python
Python实现密钥密码(加解密)实例详解
2020/04/26 Python
Python类super()及私有属性原理解析
2020/06/15 Python
消防安全标语
2014/06/07 职场文书
党风廉政建设个人总结
2015/03/06 职场文书
任长霞观后感
2015/06/16 职场文书
python正则表达式re.search()的基本使用教程
2021/05/21 Python