如何理解JavaScript中的原型链


本文摘自PHP中文网,作者清浅,侵删。

JavaScript中的原型链指的是原型对象链接到另一个原型对象并且依此类推,它的作用就是当请求对象不包含属性时,js就会一直向下查看原型链直到找到所要请求的属性或者到链的末尾

JavaScript是一种基于原型的语言,也就是说JavaScript中的对象属性和方法可以通过克隆或者扩展实现通用对象共享。这就称为原型继承。接下来在文章中为大家详细介绍JavaScript中的原型链,希望对大家有所帮助

【推荐课程:JavaScript教程】

JavaScript中的每一个东西几乎都可以看作是一个对象,对象包含可以使用的obj.propName 或者是访问的命名属性obj['propName'],每个对象都有一个名为prototype的内部属性,它链接到另一个对象。原型对象也有自己的原型对象依此类推,这就被称为原型链。如果你遵循一个对象的原型链,最终会到达Object 原型所在的核心原型,标志着null链的末端。

原型链的作用是当请求对象不包含的属性时,JavaScript就会向下查看原型链,直到它找到所请求的属性,或者直到它到达链的末尾。这种行为允许我们创建“类”并实现继承。

1

2

function Animal() {}

var animal = new Animal();

Animal通过两种方式向类添加属性。一种是通过将它们设置为实例属性,还有一种是将它们添加到Animal原型中

1

2

3

4

5

6

7

8

function Animal(name) {

    this.name = name;

    }

     Animal.prototype.speak = function() {

    console.log("My name is " + this.name);

    };

    var animal = new Animal('Monty');

    animal.speak();

输出结果:My name is Monty

Animal当我们在控制台中检查它时,对象的结构变得清晰。我们可以看到name属性属于对象本身,同时speak也是Animal原型的一部分。

扩展Animal类来创建一个Cat类

1

2

3

4

5

6

function Cat(name) {

    Animal.call(this, name);

    }

Cat.prototype = new Animal();

var cat = new Cat('Monty');

cat.speak();

输出结果:My name is Monty

从上图中我们可以看出Cat对象具有自己的name实例属性,同时它也继承Animal的name实例属性以及speak原型属性。这就是原型链的作用,当我们请求cat.name时,JavaScript会找到name实例属性并且不会使用到原型链。但是当我们请求cat.speak时,JavaScript必须沿着原型链向下移动,直到找到speak继承自的属性Animal

总结:以上就是本篇文章的全部内容了,希望对大家有所帮助

以上就是如何理解JavaScript中的原型链的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

通过javascript函数生成字符串的所有排列组合

javascript如何实现异步

javascript dom的详细介绍

javascript在nodejs环境下执行机制和事件循环

react可以做什么?

学习javascript地理位置信息api

javascript怎么判断是否数字

javascript怎么将对象转换为数组

详解javascript中async/await的使用方法

javascript也用import吗

更多相关阅读请进入《javascript》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...