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

js中什么是原型链

在JavaScript中,原型链是一种实现对象间继承的机制。每个JavaScript对象都有一个指向其原型对象的内部链接,这个原型对象也是一个普通的对象,并包含一些属性和方法。如果在一个对象上找不到某个属性或方法,JavaScript引擎会沿着这个对象的原型链向上查找,直到找到该属性或方法,或者到达原型链的末端(即null)。

基础概念

  1. 原型对象(Prototype):每个JavaScript对象都有一个原型对象,它包含了可以被其他对象共享的属性和方法。
  2. 构造函数(Constructor):用于创建和初始化对象的特殊函数。通过new关键字调用构造函数可以创建新的对象实例。
  3. __proto__属性:每个对象都有一个__proto__属性,它指向该对象的原型对象。
  4. prototype属性:每个函数都有一个prototype属性,它指向一个原型对象,该对象包含可以被该函数创建的所有实例共享的属性和方法。

优势

  • 实现了对象间的继承,提高了代码的重用性。
  • 可以动态地添加、修改或删除原型链上的属性和方法,从而影响所有相关的对象实例。

类型

  • 构造函数原型:通过构造函数的prototype属性定义的原型对象。
  • 对象字面量原型:通过对象字面量创建的对象,其原型指向Object.prototype

应用场景

  • 实现对象间的继承关系。
  • 共享方法和属性,减少内存消耗。
  • 实现JavaScript的类(class)语法糖背后的机制。

问题及解决方法

问题:为什么在原型链上查找属性或方法时,如果找不到会报错?

原因:当沿着原型链向上查找属性或方法时,如果到达原型链的末端(即null)仍然找不到,JavaScript引擎会返回undefined。但是,如果试图访问一个不存在的属性或方法的值,就会报错。

解决方法:在使用属性或方法之前,先检查它们是否存在。可以使用typeof操作符或者直接比较属性是否为undefined

示例代码

代码语言:txt
复制
function Person(name) {
  this.name = name;
}

Person.prototype.sayHello = function() {
  console.log('Hello, my name is ' + this.name);
};

var john = new Person('John');

// 访问存在的属性
console.log(john.name); // 输出: John

// 访问不存在的属性,返回undefined,不会报错
console.log(john.age); // 输出: undefined

// 调用存在的方法
john.sayHello(); // 输出: Hello, my name is John

// 调用不存在的方法,会报错
// john.sayGoodbye(); // 报错: john.sayGoodbye is not a function

// 解决方法:先检查方法是否存在
if (typeof john.sayGoodbye === 'function') {
  john.sayGoodbye();
} else {
  console.log('sayGoodbye method does not exist');
}

在这个示例中,我们定义了一个Person构造函数和一个sayHello方法。当我们创建一个Person实例并尝试访问其属性和方法时,JavaScript引擎会沿着原型链查找。如果我们尝试访问一个不存在的属性或方法,就会得到undefined或报错。为了避免报错,我们可以先检查属性或方法是否存在。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • JS中的原型和原型链

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

    1.5K10

    js中的原型和原型链

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

    1.1K00

    JS原型与原型链

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

    1.8K50

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

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

    9210

    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 原型链

    JS 原型链 1. 原型和原型链的基础结论 1.1 函数与对象的关系 函数是对象,对象都是通过函数创建的。 函数与对象并不是简单的包含与被包含的关系。...1.3 原型和原型链 原型:一个函数可以看成一个类,原型是所有类都有的一个属性,原型的作用就是给这个类的一个对象都添加一个统一的方法。...1.4 JavaScript 里最顶层的两个概念 Function 是最顶层的构造器 Function 是JavaScript 里最顶层的构造器,它构造了系统中的所有对象,包括定义对象、系统内置对象、甚至包括它自己...__proto__ **前提结论:**在JavaScript中,函数都是对象,是对象就有隐藏的__proto__属性 「解释:」 Function是最顶级的构造器,函数对象都是通过它构造的 「结论:」函数...基于原型链的继承 JavaScript 对象有一个指向一个原型对象的链。

    2.3K30

    JS进阶:原型与原型链

    JS进阶:原型与原型链 image.png JavaScript中除了基础数据类型外都是对象(引用类型)。...该原型对象也有一个自己的原型对象( __proto__ ) ,层层向上直到一个对象的原型对象为 null。根据定义,null 没有原型,并作为这个原型链中的最后一个环节。...这里dog2重写bark方法并没有对dog1造成影响,因为它重写bark方法的操作实际上是为自己添加了一个新的方法使原型中的bark方法被覆盖了,而并非直接修改了原型中的方法。...//'haha~' dog2.bark() //'haha~' 这样看起来就没什么问题了,将实例中共有的属性放到原型对象中,让所有实例共享这部分属性。...通过原型链就可以在JavaScript中实现继承,JavaScript中的继承相当灵活,有多种继承的实现方法,这里只介绍一种最常用的继承方法也就是组合继承。

    1.4K30

    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进阶-原型链

    原型链的定义 JavaScript 是基于 原型(prototype) 继承的语言,每个对象都可以从它的 原型 继承属性和方法。...原型链(Prototype Chain) 就是多个对象通过 prototype 关联形成的链式结构,用于实现继承。...__proto__(原型指向):实例对象内部的 __proto__ 连接到其构造函数的 prototype,形成原型链。 实例对象....__proto__ === 构造函数.prototype 按照我自己的理解来说,就是 创建对象的那个东西长什么样子。 举个例子:有一批东西产品,是从一个模具做出来的。...下面用js来深刻体会一下原型链: // 1 定义一个模具(构造函数) function Product(color) { this.color = color; // 每个产品(实例)都有不同的颜色

    7310

    JS原型链温故

    在js中,对于对象的理解很重要。 js的数据类型主要分为基本类型和引用类型。基本类型包括String、Number、Boolean、undefined、null。引用类型包括Object。...至于向数组添加属性和方法,在实际工作中数组的方法使用的应该不少了吧,比如concat、slice之类的,所以结论是只要是对象,js中都可以自由添加属性和方法。 现在我们明确知道,函数就是对象的一种。...所以结合上面几个图,可以形成这样一个结论: 在JS世界中,null为开始,由null开始衍生出Object.prototype。Object.prototype的隐式原型链指向null。...从上图可以看出一个关系,那就是js中的各对象间都是通过原型链来互相连接起来的,这个原型链将所有对象链接在了一起,这就是为什么说JS是基于原型的面向对象编程语言,即使现在有es6 7有了class类,它本质上也是基于原型链形成的语法糖而已...js中实现的继承就是通过这条原型链来工作的:在访问一个对象的某个属性时,先该对象的现有属性中查找,如果没有,再沿着__proto__这种链向上找,这就是原型链。

    1.3K20

    理解JS 原型链

    一直以来对于JavaScript 的原型链的概念,始终有些东西有一种模糊感,最近刚好有时间就塌下心认真的把《JavaScript高级程序设计》中相关内容认真读了一遍,也查看了很多网上很多资料,以前很多不明白的地方也渐渐明白了起来...但是你总不能说他们是一间麦当劳吧?...#原型链 原型链简单用一句话概括就是: 原型链就是 对象的__proto__所连接的链状结构 为了方便我们理解原型链,举一个简单的例子: function F(){ this.a = 1;...#补充 constructor 说一下我的经历,一开始理解原型链时,一直在prototype、__proto__、constructor在这个三个属性中绕来绕去。...null 既然对象都会继承自Object.prototype上面的方法,那它自己的原型又是什么呢。答案是null Object.prototype.

    1.7K10

    【深入理解JS核心技术】2. 什么是原型链?

    原型链是用于在现有对象的基础上构建新类型的对象。它类似于基于类的语言中的继承。...构造函数,原型,实例的关系: 每个构造函数都有一个原型对象,原型有一个属性指回构造函数,而实例有一个内部指针指向原型。 原型链的基本思想:(如果原型是另一个类型的实例?)原型当成实例。...第一种方式是使用instanceof操作符,如果一个实例的原型链中出现过相应的构造函数,则instanceof返回true。 确定关系的第二种方式是使用 isPrototypeOf() 方法。...原型链中的每个原型都可以调用这个方法。...原型中包含的引用值会在所有实例间共享,这也是为什么属性通常会在构造函数中定义而不会在原型上的原因。

    34210

    JS面试必问-JS原型及原型链

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

    1.6K20

    JS中的面向对象、原型、原型链、继承总结大全

    什么是对象 直接上《JavaScript高级教程》的截图 ?...补充: js中说一切都是对象,是不完全的,在js中6种数据类型(Undefined,Null,Number,Boolean,String,Object)中,前五种是基本数据类型,是原始值类型,这些值是在底层实现的...showName 这种构造函数模式和原型模式组合使用,基本上可以说是js中面向对象开发的一种默认模式,介绍了以上这几种常用创建对象的方式, 还有其他不常用的模式就不介绍了,接下来想说的是js中比较重要的继承...继承 什么是原型链 ECMA中继承的主要方法就是通过原型链,主要是一个原型对象等于另一个类型的实例,由于实例内部含有一个指向构造函数的指针,这时候相当于重写了该原型对象,此时该原型对象就包含了一个指向另一个原型的指针...属性查找机制 js中实例属性的查找,是按照原型链进行查找,先找实例本身有没有这个属性,如果没有就去查找查找实例的原型对象,也就是[[prototype]]属性指向的原型对象,一直查到Object.prototype

    1.4K22

    彻底搞懂JS原型与原型链

    说到JavaScript的原型和原型链,相关文章已有不少,但是大都晦涩难懂。本文将换一个角度出发,先理解原型和原型链是什么,有什么作用,再去分析那些令人头疼的关系。...也就是说 数组是对象、函数是对象、正则是对象、对象还是对象。图片二、原型和原型链是什么上面我们说到对象就是属性(property)的集合,有人可能要问不是还有方法吗?...现在我们已经初步理解了原型和原型链,到现在大家明白为什么数组都可以使用push、slice等方法,函数可以使用call、bind等方法了吧,因为在它们的原型链上找到了对应的方法。...参考视频讲解:进入学习五、原型链顶层原型链之所以叫原型链,而不叫原型环,说明它是有始有终的,那么原型链的顶层是什么呢?...我们来看一下MDN上对于instanceof运算符的描述:instanceof运算符用于测试构造函数的prototype属性是否出现在对象的原型链中的任何位置也就是说instanceof操作符左边是一个对象

    2.4K30
    领券