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 相关文章推荐
javascript作用域和闭包使用详解
Apr 25 Javascript
当滚动条滚动到页面底部自动加载增加内容的js代码
May 13 Javascript
Jquery 返回json数据在IE浏览器中提示下载的问题
May 18 Javascript
js数值计算时使用parseInt进行数据类型转换(jquery)
Oct 07 Javascript
html的DOM中document对象anchors集合用法实例
Jan 21 Javascript
jquery中绑定事件的异同
Feb 28 Javascript
使用jQuery实现页面定时弹出广告效果
Aug 24 jQuery
利用jquery和BootStrap实现动态滚动条效果
Dec 03 jQuery
Vue.js@2.6.10更新内置错误处机制Fundebug同步支持相应错误监控
May 13 Javascript
ES6 Object属性新的写法实例小结
Jun 25 Javascript
vue cli3 调用百度翻译API翻译页面的实现示例
Sep 13 Javascript
Vue使用预渲染代替SSR的方法
Jul 02 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中用header图片地址 简单隐藏图片源地址
2008/04/09 PHP
10个php函数实用却不常见
2015/10/13 PHP
php socket通信简单实现
2016/11/18 PHP
php 反斜杠处理函数addslashes()和stripslashes()实例详解
2016/12/25 PHP
javascript编程起步(第四课)
2007/01/10 Javascript
JQuery 初体验(建议学习jquery)
2009/04/25 Javascript
13个绚丽的Jquery 界面设计网站推荐
2010/09/28 Javascript
css样式标签和js语法属性区别
2013/11/06 Javascript
JS实现匀速运动的代码实例
2013/11/29 Javascript
js中switch case循环实例代码
2013/12/30 Javascript
javascript作用域和闭包使用详解
2014/04/25 Javascript
两种不同的方法实现js对checkbox进行全选和反选
2014/05/13 Javascript
通过jquery 获取URL参数并进行转码
2014/08/18 Javascript
原生javascript实现隔行换色
2015/01/04 Javascript
javascript弹出窗口实现代码
2015/11/12 Javascript
javascript计时器编写过程与实现方法
2016/02/29 Javascript
jquery实现数字输入框
2017/02/22 Javascript
详谈JS中数组的迭代方法和归并方法
2017/08/11 Javascript
对angularJs中自定义指令replace的属性详解
2018/10/09 Javascript
JavaScript数组、json对象、eval()函数用法实例分析
2019/02/21 Javascript
swiper实现异形轮播效果
2019/11/28 Javascript
编写一个javascript元循环求值器的方法
2020/04/14 Javascript
jQuery实现飞机大战小游戏
2020/07/05 jQuery
[41:17]完美世界DOTA2联赛PWL S3 access vs CPG 第二场 12.13
2020/12/17 DOTA
用python脚本24小时刷浏览器的访问量方法
2018/12/07 Python
python 画二维、三维点之间的线段实现方法
2019/07/07 Python
基于Pyinstaller打包Python程序并压缩文件大小
2020/05/28 Python
CSS3 三维变形实现立体方块特效源码
2016/12/15 HTML / CSS
简单掌握CSS3中resize属性的用法
2016/04/01 HTML / CSS
全球地下的服装和态度:Slam Jam
2018/02/04 全球购物
公司年会演讲稿范文
2014/01/11 职场文书
经典安踏广告词
2014/03/21 职场文书
房产继承公证书
2014/04/09 职场文书
如何撰写一封出色的求职信
2014/04/27 职场文书
利用前端HTML+CSS+JS开发简单的TODOLIST功能(记事本)
2021/04/13 Javascript
CentOS7设置ssh服务以及端口修改方式
2022/12/24 Servers