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

JS中的原型和原型链

原型 JavaScript规定,每一个函数都有一个prototype对象属性,指向另一个对象。prototype对象属性的所有属性和方法都会被构造函数的实例继承。...js在创建对象的时候,都有一个叫做proto的属性,用于指向它的函数对象的原型对象prototype。 prototype可以让所有的对象实例共享它包含的属性和方法。...原型链 每一个对象都可以有一个原型,这可原型还可以有它自己的原型,以此类推,就形成了原型链。...查找一个对象的属性或方法的时候,如果这个对象中没有这个属性或者方法,那就会在这个对象的原型对象中去找,以此类推,直到原型链结束。..._proto_ _proto_是原型链查询中实际用到的,指向构造函数的原型对象,他是对象独有的。对象._proto_ = 构造函数.prototype。 在js中,万物皆是对象,函数也是对象。

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

    js中的原型和原型链

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

    1.1K00

    说说JS中的原型对象和原型链

    理解原型对象(有些文章简称为原型)和原型链,是理解JS的重要一环。下面是笔者对JS中原型的理解, 函数对象 俗话说,JS中万物皆对象。函数也是一个对象,只不过函数是在特定环境中执行代码的对象。...千言万语不如一幅图: 原型链 由上节我们可以知道,原型对象上的属性和方法被所有实例所共享的。...如果原型对象和实例上具有同名的属性或方法,则搜索时取最近的。 如上述的原型链的搜索机制,你通过阅读本文知道xiaoming.__proto__是Person.prototype,但xiaoming....不说话看图: 由此,可得到下面的关系图: 思考 原型链中的关系图其实还缺少一环,就是内置函数Function。...本文是笔者对原型对象和原型链的理解,如有错误或不足的地方,欢迎指正。

    9210

    原型和原型链理解_原型对象和原型链

    一、原型 ①所有引用类型都有一个__proto__(隐式原型)属性,属性值是一个普通的对象 ②所有函数都有一个prototype(原型)属性,属性值是一个普通的对象 ③所有引用类型的__proto...__proto__ === Array.prototype; // true 二、原型链 当访问一个对象的某个属性时,会先在这个对象本身属性上查找,如果没有找到,则会去它的__proto__隐式原型上查找...,即它的构造函数的prototype,如果还没有找到就会再在构造函数的prototype的__proto__中查找,这样一层一层向上查找就会形成一个链式结构,我们称为原型链。...,会执行下面步骤: 访问链路为: ①一直往上层查找,直到到null还没有找到,则返回undefined ②Object.prototype....__proto__ === null ③所有从原型或更高级原型中的得到、执行的方法,其中的this在执行时,指向当前这个触发事件执行的对象 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人

    58730

    js对象和原型、原型链的关系

    JS的原型、原型链一直是比较难理解的内容,不少初学者甚至有一定经验的老鸟都不一定能完全说清楚,更多的"很可能"是一知半解,而这部分内容又是JS的核心内容,想要技术进阶的话肯定不能对这个概念一知半解,碰到问题靠...》:在js中, 实际上并不存在所谓的'构造函数',只有对于函数的'构造调用'。...是原型链的终点,所有对象都是从它继承了方法和属性。...foo1.obkoro1和foo1.koro:返回undefined静态属性: foo.obkoro1、foo.koro函数在JS中是一等公民,它也是一个对象, 用来模拟类。...它们只能通过foo.obkoro1和foo.koro来访问。原型对象改变,原型链下游获取的值也会改变上面那个例子中的foo1.test的值是什么?

    1.5K20

    JS完美收官——原型和原型链

    原型和原型链这部分知识会影响到写面试题,或者做一些公共的组件和插件,总之是通用型的一些东西 原型 prototype 「所有的函数都有一个属性prototype,称之为函数原型」。...,add原型中又有一个属性constructor,它指向构造函数add本身。...刚刚在原型中也说了一句话:所有的函数都有一个属性prototype,称之为函数原型 「灵魂拷问:」 test是个函数,请问test是否有__proto__属性?...当访问一个对象的成员时,首先会看看对象自身是否拥有该成员,如果有直接使用;如果没有,会在原型链中依次查找是否拥有该成员,如果有直接使用 如果有一天发现函数原型上的方法不够用,我们可以自己写函数添加到原型上...原型链 我们先来看一张图,理解了图,原型链也就理解了 我们先看白色的箭头,白色表示函数的原型,每一个函数都有原型,Object函数的原型是Object对象【①】,那么自定义函数也是有原型的,自定义函数的原型也是一个对象

    42610

    【JS】479- 又见原型和原型链

    通过这篇文章你将掌握以下知识点: 理解 __proto_; 理解 prototype; 理解javascript中对象的概念; 理解原型和原型链; 理解javascript中类的概念; 理解new的实现...那么说到对象,我们从上面可以看出,一个对象是通过构造函数 new 出来的,这其实跟原型和原型链有很大的关系,那么原型和原型链到底是用来干嘛的呢?...javascript中的类 刚刚我们终于明白什么是 原型 和 原型链。下面我们根据上面的概念来讲解一下javascript中的类。...所以在 javascript 中 ,类都是通过原型和原型链来实现的,它其实是一种委托方式。...res : obj; } 复制 instanceof的实现 那么学习了原型和原型链,instanceof的实现肯定也很简单了,它也是通过原型和原型链来实现的: function myInstanceof

    69130

    原型、原型链和原型继承

    原型继承 编程中对象继承,有类继承和原型继承: 类继承形式上就是,extends 关键字,继承之后,子类就会拥有父类的属性和方法,如下: // 以下是 ES6 class 语法,语法上同类继承一样,但实际上仍然是原型继承...该对象就是我们说的原型。 它的作用就是用来存放一些方法和属性,当以它为原型的对象,访问本身没有的一些属性或者方法,就会来到原型上面查找。...那么上面继承过程中,prototype 是什么, 它有什么用呢?...构造函数的 prototype 和实例对象的原型,其实是指向同一个对象的。 原型链 上面两节,我们搞清楚原型是什么,以及 构造函数 prototype 是什么了。那么原型链又是什么呢?...而javascript 运行环境中是预设了一些对象来作为原型的,如图: 查找属性或方法时,向上追溯,经过的原型,就形成了一条链,所谓原型链。 至于运行环境预设了哪些原型,已经他们的关系如何,为什么?

    76110

    原型和原型链

    导读: 分类:面试总结 题目:原型和原型链 基础很重要,时刻给自己充电!...1.题目 如何准确判断一个变量是数组 写一个原型链继承的例子 继承实现的其他方式 描述new一个对象的过程 zepto及其他源码中如何使用原型链 2.知识点 2.1 构造函数 特点:以大写字母开头 function...在构造函数中通过call函数可以继承父类构造函数的属性和方法,但是通过这种方式实例化出来的实例会将父类方法多次存储,影响性能。...3.扩展OutgoingMessage自身原型的函数。 inherits方法中使用了Object.create方法,该方法的作用是通过指定的原型对象和属性创建一个新的对象。...false] 3.4 描述new一个对象的过程 创建一个对象 {}.proto = 构造函数.prototype this指向这个对象 执行代码即对this赋值 返回this 3.5 zepto及其他源码中如何使用原型链

    59730

    原型和原型链

    prototype(原型):prototype是Function对象的一个属性,它定义了构造函数制造出的对象的公用祖先(属性和方法),可以继承该原型的属性和方法。原型也是对象。...__proto__(隐式原型):没个对象的__proto__属性指向自身构造函数的prototype。 constructor(构造器):返回对创建此对象的数组函数引用。...原型链基本概念:每个对象都会在其内部初始化一个属性,就是 proto,当我们访问一个对象的属性 时,如果这个对象内部不存在这个属性,那么他就会去proto里找这个属性,这个proto又会有自己的proto...,于是就这样 一直找下去,也就是我们平时所说的原型链的概念。...原型链--实现对象间的联系即继承的方法。

    53320

    js原型及原型链解析

    js原型、原型链 这几天闲了看了下js的原型,以下内容为个人理解,如有错误,尽请指正。...首先,明确一点:js中的对象分为普通对象和函数对象,一般我们自定义的可以被new的函数称作函数对象,另外js内置了譬如:Array、Date、Object、Function、Number、String、...,使用__proto__将所有对象联系起来,才形成了所谓的原型链,举个栗子: function Person() {} const p1 = new Person() console.log(p1....__proto__ === null) // true, Object的原型是由null"产生"的,null处于原型链顶端 这个从根本上印证了道德经那句:道(null)生一,一生二,二生三,三生万物...__proto__ === p.constructor.prototype) // true 下一节的话讲下js中的继承~

    2.2K30

    JS进阶:原型与原型链

    JS进阶:原型与原型链 image.png JavaScript中除了基础数据类型外都是对象(引用类型)。...但是由于其没有类(ES6 引入了 class,但其只是语法糖)的概念,为了保证对象之间的联系,就有了原型和原型链的概念。...该原型对象也有一个自己的原型对象( __proto__ ) ,层层向上直到一个对象的原型对象为 null。根据定义,null 没有原型,并作为这个原型链中的最后一个环节。...通过原型链就可以在JavaScript中实现继承,JavaScript中的继承相当灵活,有多种继承的实现方法,这里只介绍一种最常用的继承方法也就是组合继承。...然后用Dog函数创建了一个实例作为Husky的原型对象赋值给Husky.prototype以继承方法。这样,通过Husky函数创建的实例就拥有了Dog中的属性和方法。

    1.4K30

    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 中不可避免需要碰到的知识点?,本文使用图片思维导图的形式缕一缕原型、原型链、实例、构造函数等等概念之间的关系?...在读取一个实例的属性的过程中,如果属性在该实例中没有找到,那么就会循着 __proto__ 指定的原型上去寻找,如果还找不到,则尝试寻找原型的原型?...,比方说这里有个构造函数 Person 然后“继承”前者的有一个构造函数 People,然后 new People 得到实例 p 当访问 p 中的一个非自有属性的时候,就会通过 __proto__ 作为桥梁连接起来的一系列原型...这个搜索的过程形成的链状关系就是原型链 20190314144733.png 如下图: 20190314145239.png 看到 null 了么,原型链搜索搜到 null 为止,搜不到那访问的这个属性就是不存在的...: 20190314145540.png 以上,这就是原型、原型链、构造函数、实例、null 之间的关系。

    56120
    领券