首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

图解原型原型

图解原型原型原型原型链是 JS 中不可避免需要碰到的知识点?,本文使用图片思维导图的形式缕一缕原型原型链、实例、构造函数等等概念之间的关系?...在读取一个实例的属性的过程中,如果属性在该实例中没有找到,那么就会循着 __proto__ 指定的原型上去寻找,如果还找不到,则尝试寻找原型原型?...: 20190314143837.png 我们把注释删掉,给实例同名属性,可以看到打印出来的属性就指向这个: 20190314143944.png 原型原型同样也可以通过 __proto__ 访问到原型原型...、原型原型原型原型原型直到 Object 构造函数为止。...: 20190314145540.png 以上,这就是原型原型链、构造函数、实例、null 之间的关系。

53120

图解 JavaScript 原型原型

('xxx'); bar.toString(); 这些代码都不知不觉间用到了原型的知识~ 如果你还对原型一知半解, 是时候静下心把它弄懂了....本文是一个系列, 该篇会介绍以下两个知识点 原型 原型原型 任何一个函数, 都拥有一个 prototype 属性, 它指向这个函数的原型对象, 如 function Foo () {} console.log...上图左边代表 Foo 函数, 它有一个 prototype 属性, 指向右侧这个原型对象, 每声明一个函数, 都会有这样的一个原型对象, 原型对象有一个 constructor 属性, 指向 Foo 函数本身...我们来看 Foo 函数的实例化: const foo = new Foo(); 这里通过我们 new 操作符实例化了一个 foo 对象, 我们来看此时的图解: ?...这就是原型链, 我们也可以说, Foo 继承了 Object, 所以 foo 中能访问到 Object 的原型属性. 原型链的内容就到这里, 更多关于继承的内容, 会在下一篇讲解.

86120
您找到你想要的搜索结果了吗?
是的
没有找到

图解JavaScript对象原型原型

+黄色实心代表prototype属性为函数对象; 橘黄色圈圈+蓝绿色实心代表prototype属性为普通对象; 图中,prototype属性就是可以被继承的原型原型可以是函数,也可以是普通对象,没有原型的对象为数不多...,Object.prototype就是其中之一,如图中右侧所示Object.prototype原型链箭头指向null,这里是所有原型链的终点,也意味着原型链到此结束,满足: Object.prototype...几乎所有函数,不论是JS内置构造函数,还是我们创建的函数,它们的原型都是Function.prototype,满足: Date....Function除外,因为Function.prototype的特殊之处在于,它是可执行的函数对象,不是普通对象: typeof Function.prototype // "function" 让我觉得JS...,因为Object.prototype自身也是对象,它的原型却是null,也可说它没有原型,也可以说它的原型是空。

51820

图解JavaScript原型

假设父类 parentScope 有如下成员属性 : aString, aNumber, anArray, anObject 子类 childScope 继承父类 parentScope,现在的原型链结构如下...childScope 尝试去访问 parentScope 中定义的属性,JavaScript 会先在 childScope 中查找,如果没有该属性,则找它继承的 scope 去获取属性,如果继承的原型对象...parentScope中都没有该属性,那么继续在它的原型中寻找,从原型链一直往上直到到达 rootScope 执行下面的语句 childScope.aString = 'child string'...原型链并没有被查询,反而是在 childScope 中增加了一个新属性 aString。...执行操作: childScope.anArray[1] = '22' childScope.anObject.key1 = 'child prop1' 这时 原型链被查询了,因为对象 anArray

66690

JS原型原型

原型原型链 JavaScript有着七种基本类型String、Number、Boolean、Null、Undefined、Symbol、Object,前六种为基本数据类型,Object为引用类型。...值得注意的是typeof (null)会返回Object,这是因为JS二进制前三位都为0的话会被判断为Object类型,null的二进制表示是全0,自然前三位也是0,所以执行typeof时会返回Object...若stu寻找到了调用的方法或属性,则不会使用__proto__寻找原型对象。...原型链可以简单理解为将原型连成一条链,js每一次获取对象中的属性都是一次查询过程,如果在自有属性中找不到就会去原型对象中查找,如果原型对象中还查不到,就回去原型对象的原型中查找,也就是按照原型链查找,...直到查找到原型链的顶端,也就是Object的原型

1.7K50

JS面试必问-JS原型原型

为什么需要原型js中万物皆对象,对象可以说是重中之重了。每一个对象都拥有自己的属性。但是在这个世界中有很多东西都是相似的,可以归为一类,他们有共同的方法和属性。不可能让每一个对象都定义一个属性吧。...所以,在js中怎么才能让多个对象共享一个或多个方法呢?原型的出现就是为了解决这个问题。...原型对象有一个constructor属性,默认指向对应的构造函数。 什么是原型链 根据字面意思我们可以这样理解,就是将原型连成一条链。...我们上面讲过,js每一次获取对象中的属性都是一次查询过程,如果在自有属性中找不到就会去原型对象中查找,如果原型对象中还查不到,就回去原型对象的原型中查找,也就是按照原型链查找,直到查找到原型链的顶端,也就是...在js中,对象都有__proto__属性,一般这个是被称为隐式的原型,该隐式原型指向构造该对象的构造函数的原型

1.4K20

js原型入门

前言 本文主要是根据《head first javascript程序设计》摘抄学习而成,学习采用这本书主要是一位阿里大佬的建议,经过近期的学习阅读,发现确实比其他的js书籍能更好的理解和使用js的相关知识...之所以出现这样的问题,是因为我们没有充分利用好js的对象模型,其是基于原型的概念的。 原型是什么 js可以从其他对象那里继承属性和行为,更具体的说js使用原型继承。其中其行为继承的对象称为原型对象。...这个是指,会继承原型对象的属性(包括属性方法),同时在新对象中添加属性。 那么如果我们要定义一个小狗的原型,其对象图是什么样的呢?...重写原型 那如果有些时候,我们需要重写bark方法,而不用原型中的方法呢?...this是指向原型对象的,同样我们也很好理解在没有原型的时候,this调用指向的是对象本身,但是你在调用原型原型的方法时你可能认为this指向的是原型对象,其实并非如此。

1.4K11

JS 原型

JS 原型链 1. 原型原型链的基础结论 1.1 函数与对象的关系 函数是对象,对象都是通过函数创建的。 函数与对象并不是简单的包含与被包含的关系。...1.2 原型的类别 显示原型:prototype,是每个函数function独有的属性。 隐式原型: __proto__,是每个对象都具有的属性。...1.3 原型原型原型:一个函数可以看成一个类,原型是所有类都有的一个属性,原型的作用就是给这个类的一个对象都添加一个统一的方法。...原型链:每个对象都有一个__proto__,它指向它的prototype原型对象;它的prototype原型对象又有一个__proto__指向它的prototype原型对象,就这样层层向上直到最终找到顶级对象...当试图访问一个对象的属性时,它不仅仅在该对象上搜寻,还会搜寻该对象的原型,以及该对象的原型原型,依次层层向上搜索,直到找到一个名字匹配的属性或到达原型链的末尾。

2.3K30

js原型

显示原型 1.每一个构造函数都有一个prototype属性,默认指向一个空Object对象(原型对象) function fun(){ } console.log(fun.prototype ) //{...) //true 5.构造函数与它的原型对象有一个相互引用的关系 6.原型对象上添加的方法用于实例对象上使用 隐式原型 每一个实例对象都有一个__proto__属性,称之为隐式原型 对象的隐式原型的值为其对应构造函数的显示原型的值...__proto__) Fn.prototype.test = function(){ console.log('test') } fn.test() 原型链 对象属性的查找规则 原型链本质上是从隐式原型链...test2,发现有直接调用test2 当执行fn.toString(),时,自身对象没有,接下来查找它构造函数的原型对象上是否有toString(),发现没有,接下来又继续沿着Fn原型对象的构造函数的原型对象上查找找到...toString() 当执行fn.test3()时,查找自身对象没有,它直接的构造函数对象的原型对象上也没有,接下来沿着Fn原型对象的构造函数的原型对象的构造函数的原型对象上查找,这里已经找到原型链的尽头

2.1K20

彻底弄懂JS原型原型

说到JavaScript的原型原型链,相关文章已有不少,但是大都晦涩难懂。本文将换一个角度出发,先理解原型原型链是什么,有什么作用,再去分析那些令人头疼的关系。...当访问一个对象的属性时,先在对象的本身找,找不到就去对象的原型上找,如果还是找不到,就去对象的原型原型也是对象,也有它自己的原型)的原型上找,如此继续,直到找到为止,或者查找到最顶层的原型对象中也没有找到...OK,总结一下:原型存在的意义就是组成原型链:引用类型皆对象,每个对象都有原型原型也是对象,也有它自己的原型,一层一层,组成原型链。...五、原型链顶层原型链之所以叫原型链,而不叫原型环,说明它是有始有终的,那么原型链的顶层是什么呢?拿我们的person对象来看,它的原型对象,很简单// 1. person的原型对象person....在上面内容的基础之上,我们来模拟一下js引擎读取对象属性:function getProperty(obj, propName) { // 在对象本身查找 if (obj.hasOwnProperty

1.1K40

JS中的原型原型

prototype就是调用构造函数所创建的实例对象的原型(proto)。js在创建对象的时候,都有一个叫做proto的属性,用于指向它的函数对象的原型对象prototype。...原型链 每一个对象都可以有一个原型,这可原型还可以有它自己的原型,以此类推,就形成了原型链。...查找一个对象的属性或方法的时候,如果这个对象中没有这个属性或者方法,那就会在这个对象的原型对象中去找,以此类推,直到原型链结束。..._proto_ _proto_是原型链查询中实际用到的,指向构造函数的原型对象,他是对象独有的。对象._proto_ = 构造函数.prototype。 在js中,万物皆是对象,函数也是对象。...3、构造函数的prototype指向原型对象,原型对象的constructor指向构造函数。 使用 prototype最主要的用法就是将属性暴露成公用的。

1.5K10

彻底搞懂JS原型原型

说到JavaScript的原型原型链,相关文章已有不少,但是大都晦涩难懂。本文将换一个角度出发,先理解原型原型链是什么,有什么作用,再去分析那些令人头疼的关系。...当访问一个对象的属性时,先在对象的本身找,找不到就去对象的原型上找,如果还是找不到,就去对象的原型原型也是对象,也有它自己的原型)的原型上找,如此继续,直到找到为止,或者查找到最顶层的原型对象中也没有找到...OK,总结一下:原型存在的意义就是组成原型链:引用类型皆对象,每个对象都有原型原型也是对象,也有它自己的原型,一层一层,组成原型链。...参考视频讲解:进入学习五、原型链顶层原型链之所以叫原型链,而不叫原型环,说明它是有始有终的,那么原型链的顶层是什么呢?...在上面内容的基础之上,我们来模拟一下js引擎读取对象属性:function getProperty(obj, propName) { // 在对象本身查找 if (obj.hasOwnProperty

1.3K20

js中的原型原型

​一、原型 1、prototype和constructor 在js中每个函数(非箭头函数,一般关于原型的有关知识我们都只考虑构造函数)都会拥有一个 prototype 属性,该属性值是一个对象...,我们称之为原型对象。...__proto__) // true 二、原型原型链:《JavaScript高级程序设计》中的描述是:每个构造函数都有一个原型对象,如果该原型是另一个类型的实例呢?...那就意味着这个原型本身有一个内部指针指向另一个原型,相应地另一个原型也有一个指针指向另一个构造函数。这样就在实例和原型之间构造了一条原型链。这就是原型链的基本构想。...原型链中的查找机制:实例对象上找不到指定属性,就从该原型对象上找,如果还是找不到就到该原型对象上的原型上去找,。

1.1K00
领券