javascript的原型与原型链
首先套用一句经典名言,JavaScript中万物皆对象。
但是对象又分为函数对象和普通对象。
function f1(){};
var f2=function(){};
var f3=new Function('name','console.log(name)');
所有 Function 的实例(上面三种方式)都是函数对象,其他的均为普通对象,其中包括 Function 实例的实例也为普通对象。
原型的概念:每一个javascript对象(除null外)创建的时候,就会与之关联另一个对象,这个对象就是我们所说的原型,每一个对象都会从原型中“继承”属性。
说到原型,必不可少的就是三个名词__proto__,prototype,constructor。
1.prototype
在JavaScript中,每个函数都有一个prototype属性,这个属性指向函数的原型对象。见代码:
function Monkey(name){
this.name=name;
}
Monkey.prototype.age=500;
var monkey1=new Monkey('熏悟空');
var monkey2=new Monkey('逼马吻');
console.log(monkey1.age); //500
console.log(monkey2.age); //500
上述例子中,函数Monkey的prototype指向了一个对象,而这个对象正是调用构造函数时创建的实例的原型对象,也就是person1和person2的原型对象。
2.__proto__
这是每个对象(除null外)都会有的属性,这个属性会指向该对象的原型对象。
function Pig(name){
this.name=name
}
var pig1=new Pig('猪扒盖');
console.log(pig1.__proto__===Pig.prototype); //true
以上代码中函数对象Pig的prototype指向它的原型对象。Pig的实例对象pig1的__proto__指向Pig的原型对象,所以pig1.__proto__===Pig.prototype为true。
3.constructor
每个原型对象都有一个constructor属性,指向该关联的构造函数。
function Pig(){}
console.log(Pig===Pig.prototype.constructor); //true
4.实例与原型的关系。
当我们获取实例对象的属性时首先会访问自身的属性,如果没有查找到,就往该实例对象对应的原型对象中查找,如果还是查找不到就继续往原型对象的原型对象上面查找,一直找到最顶层null为止。
function Monkey(){}
Monkey.prototype.name='熏悟空';
var monkey1=new Monkey();
monkey1.name='逼马吻';
console.log(monkey1.name); //逼马吻
detele monkey1.name;
console.log(monkey1.name); //熏悟空
上面代码中实例对象monkey1获取name属性时因为给其本身赋了值,所以获取到了‘逼马吻’,当我删除了monkey1的name属性时,monkey1本身就没有了name值,因此便往monkey1的原型对象上面寻找,找到了‘熏悟空’。如果没有找到的话就会继续往上找,一直找到null为止。
5.原型的原型
由上我们可以知道,原型其实也是个对象,既然是对象那么便可以通过new Object的方式创建,实际上实例对象也是通过Object构造函数的方式创建,由于实例对象的原型指向构造函数的实例对象,因此我们可以得出原型的最终原型对象就是Object的原型对象,而Object的原型是null。
最后,总结一下关系:
每个构造函数都有一个原型对象(prototype),原型对象都包含一个指向构造函数的指针(constructor),而实例都包含一个指向原型对象的内部指针(__ptoto__);而原型链就是通过各个原型对象不断往里查找的过程中所形成的整体链接。
文章原文:https://www.cnblogs.com/loveyaxin/p/11151586.html
javascript的原型与原型链的更多相关文章
- JavaScript之继承(原型链)
JavaScript之继承(原型链) 我们知道继承是oo语言中不可缺少的一部分,对于JavaScript也是如此.一般的继承有两种方式:其一,接口继承,只继承方法的签名:其二,实现继承,继承实际的方法 ...
- 【javascript基础】4、原型与原型链
前言 荒废了好几天,在宿舍闷了几天了,一直想着回家放松,什么也没搞,论文就让老师催吧.不过,闲的没事干的感觉真是不好,还是看看书,写写博客吧,今天和大家说说函数的原型. 原型是什么 第一次看到这个的时 ...
- 【JavaScript】深入理解JavaScript之强大的原型和原型链
由于JavaScript是唯一一个被广泛使用的基于原型继承的语言,所以理解两种继承模式的差异是需要一定时间的,今天我们就来了解一下原型和原型链. AD: hasOwnProperty函数: hasOw ...
- 《JavaScript 闯关记》之原型及原型链
原型链是一种机制,指的是 JavaScript 每个对象都有一个内置的 __proto__ 属性指向创建它的构造函数的 prototype(原型)属性.原型链的作用是为了实现对象的继承,要理解原型链, ...
- Javascript 原型和原型链
先来了解一下Javascript中的原型:”原型也是一个对象,原型可以用来实现继承...“ 对于 原型,构造函数,以及实例之间的关系:“每个(构造)函数都有一个原型属性,原型对象都包含一个指向构造函数 ...
- javascript 原型 和 原型链
最近几天,好些新同事来问原型,原型链啥的.本身作为菜鸟的我好像也没有好好整理过这个,这里写写自己的理解. 原型 大家都知道,JavaScript 不包含传统的类继承模型,而是使用 prototype ...
- JavaScript深入之从原型到原型链(本文转载)
JavaScript深入之从原型到原型链(本文转载) https://github.com/mqyqingfeng/Blog.原文地址 构造函数创建对象 我们先使用构造函数创建一个对象: functi ...
- javascript 之原型、原型链-14
原型 原型是一个对象,每个函数对象(在javascript 之对象中说过函数也是对象 )都有一个属性(prototype)指向这个对象--原型对象,这个对象的作用是让所有对象实例共享原型对象中的属性. ...
- JavaScript原型与原型链
一.数据类型 JavaScript的数据类型可以分为基本数据类型和引用数据类型. 基本数据类型(6种) String Number Boolean null undefined Symbol(ES6) ...
- JavaScript prototype原型和原型链详解
用过JavaScript的同学们肯定都对prototype如雷贯耳,但是这究竟是个什么东西却让初学者莫衷一是,只知道函数都会有一个prototype属性,可以为其添加函数供实例访问,其它的就不清楚了, ...
随机推荐
- 树莓派-openeuler安装
一.安装准备 1.硬件安装 2.下载openeuler镜像 3.sd卡格式化 sd格式化工具 4.镜像校验 二.镜像烧写 选择树莓派官方烧写工具,耐心等待... 三.网络配置 1.寻找树莓派的ip地址 ...
- PHP笔记1__基础知识
客户端: 美妙的网页组成(都是由浏览器解释): 1.HTML 2.CSS--给HTML化妆 3.客户端脚本编程语言(JavaScript等)--特效 服务器端: 1.Web服务器Apache/Ngi ...
- win10 python3.8 wxpython.whl 安装步骤
wxpython是python开发常用图形用户界面(GUI)工具之一,GUI因其直观便捷,对我们提高开发效率一定帮助.这里介绍一下新版本wxPython 4.0.1的安装过程及注意事项. 第1步:下 ...
- spring boot+vue实现H5聊天室客服功能
spring boot+vue实现H5聊天室客服功能 h5效果图 vue效果图 功能实现 spring boot + webSocket 实现 官方地址 https://docs.spring.io/ ...
- Windows漏洞:MS08-067远程代码执行漏洞复现及深度防御
摘要:详细讲解MS08-067远程代码执行漏洞(CVE-2008-4250)及防御过程 本文分享自华为云社区<Windows漏洞利用之MS08-067远程代码执行漏洞复现及深度防御>,作者 ...
- 架构小试之IDL
本文转载自我自己的博客,感兴趣的老爷们可以关注~:https://www.miaoerduo.com/2021/11/16/arch-idl/ 为什么IDL的介绍也放在这里呢?一方面是我想不到放哪里, ...
- 仿Word的支持横轴竖轴的WPF 标尺
最近在 https://mp.weixin.qq.com/s/3dEO0NZQv5YLqK72atG4Wg 官方公众号看到了 用WPF 制作 标尺 在去年项目上也接到了一个需求,用于排版自定义拖 ...
- Hadoop集群 增加节点/增加磁盘
在虚拟机中新建一个机器. 设置静态IP 将修改/etc/hosts 192.168.102.10 master 192.168.102.11 slave-1 192.168.102.12 slave- ...
- [bzoj1593]旅馆
用线段树维护区间中最大的一段连续的1,以左端点为左端点最大的一段连续的1,以右端点为右端点最大的一段连续的1,然后就可以支持区间修改和查询了 1 #include<bits/stdc++.h&g ...
- nginx安装与配置1-nginx安装
反向代理: 客户端不需要配置就可以访问,将请求发送到反向代理服务器, 由反向代理服务器选择目标服务器获取数据,再返回客户端,对外暴露代理服务器地址,隐藏真实ip 负载均衡: 客户端请求nginx等服务 ...