【JavaScript】原型

这篇具有很好参考价值的文章主要介绍了【JavaScript】原型。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在 JavaScript 中,每个对象都有一个原型(prototype),它是一个对象本身,而不是一个函数。原型机制是 JavaScript 的核心特性之一,它允许对象继承另一个对象的属性和方法。

以下是关于 JavaScript 原型的基本概念和用法:

  1. 原型链:

    每个对象都有一个原型,而原型本身也是一个对象,因此可以形成一个原型链。当访问一个对象的属性或方法时,JavaScript 首先在对象本身查找,然后在其原型上查找,如果还没有找到,就会继续在原型的原型上查找,以此类推,直到找到或者到达原型链的末端。

  2. prototype 属性:

    在 JavaScript 中,构造函数(函数用于创建对象)有一个 prototype 属性,它是一个对象,用于存储该构造函数的实例共享的属性和方法。当使用构造函数创建对象时,对象会继承构造函数的 prototype 对象的属性和方法。

  3. __proto__ 属性:

    每个对象都有一个 __proto__ 属性,它指向对象的原型。通过 __proto__ 属性,可以访问对象的原型上的属性和方法。

  4. 原型的继承:

    • 当一个对象被用作另一个对象的原型时,那么这个对象就是继承者的原型。
    • 继承者对象可以访问原型对象的属性和方法,就好像它自己拥有这些属性和方法一样。
    • 如果继承者对象自身有和原型对象同名的属性或方法,那么它会覆盖原型对象的属性或方法。

以下是一个简单的示例,展示了原型的概念:

// 构造函数
function Person(name) {
  this.name = name;
}

// 在构造函数的 prototype 上添加方法
Person.prototype.sayHello = function() {
  console.log(`Hello, my name is ${this.name}`);
};

// 创建对象
const person1 = new Person("Alice");
const person2 = new Person("Bob");

// 调用原型上的方法
person1.sayHello(); // 输出:Hello, my name is Alice
person2.sayHello(); // 输出:Hello, my name is Bob

// 使用 __proto__ 访问原型
console.log(person1.__proto__ === Person.prototype); // true
console.log(person2.__proto__ === Person.prototype); // true

在这个示例中,Person 是一个构造函数,Person.prototype 是一个对象,我们将方法 sayHello 添加到了 Person.prototype 上。当创建 person1person2 对象时,它们继承了 Person.prototype 的属性和方法,因此可以调用 sayHello 方法。


类的原型对象:

类是构造函数的语法糖,因此类的实例化过程实际上也是通过构造函数来创建对象的,因此类和构造函数都具有原型的概念。

在类中,类的原型可以被称为类的原型对象(class prototype object),它类似于构造函数的原型。类的实例会继承类的原型对象上的方法和属性,类似于使用构造函数创建的对象会继承构造函数的原型上的方法和属性。

下面是一个简单的示例,展示了类的原型的概念:

class Person {
  constructor(name) {
    this.name = name;
  }

  sayHello() {
    console.log(`Hello, my name is ${this.name}`);
  }
}

const person1 = new Person("Alice");
const person2 = new Person("Bob");

person1.sayHello(); // 输出:Hello, my name is Alice
person2.sayHello(); // 输出:Hello, my name is Bob

console.log(person1.__proto__ === Person.prototype); // true
console.log(person2.__proto__ === Person.prototype); // true

在这个示例中,Person 是一个类,Person.prototype 是类的原型对象,我们在类中定义了方法 sayHello,该方法被添加到了 Person.prototype 上。当创建 person1person2 对象时,它们继承了 Person.prototype 的属性和方法,因此可以调用 sayHello 方法。

总之,类和构造函数都具有原型的概念,类的实例化过程实际上也是通过构造函数来实现的,因此类的原型在类的继承和方法共享方面具有重要作用。


下面是一个简单的示例来说明原型链的概念:

function Tree(height) {
    this.height = height;
}

Tree.prototype.getHeight = function () {
    return this.height;
}

const highTree = new Tree(10);

// highTree.__proto__ === Tree.prototype; // true
// Tree.__proto__ === Function.prototype; // true

// highTree.__proto__.__proto__ === Object.prototype; // true
// highTree.__proto__.__proto__ === Function.prototype  // false
// Object.prototype.__proto__ === null; // true

// Object.__proto__ === Function.prototype; // true
// Function.__proto__ === Function.prototype; // true
// Function.prototype.__proto__ === Object.prototype; // true

这就是 JavaScript 中的原型链的基本概念和工作原理。原型链为对象之间的继承提供了一种机制,在 JavaScript 中实现了面向对象编程的特性。

new 对象的过程文章来源地址https://www.toymoban.com/news/detail-671837.html

  1. {}
  2. {}.__proto__ = Tree.prototype
  3. {}.__proto__.constructor()(类)|(如果是函数,则执行函数内代码)
  4. return instance 返回实例

到了这里,关于【JavaScript】原型的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • javascript中的prototype;javascript中的原型链

    在JavaScript中,每个对象都有一个原型(prototype),并且原型可以有自己的原型,形成了一个链式结构,被称为原型链。这个机制是JavaScript中实现继承和对象属性查找的基础。 原型链是由对象之间的连接构成的。每个对象都有一个指向它原型的链接,这个链接可以追溯到顶层

    2024年02月20日
    浏览(41)
  • 开发语言漫谈-JavaScript

           JavaScript、Java名字很相近,但它们没有任何亲缘关系,是由不同公司开发的编程语言。Java由Sun公司(后被Oracle收购)开发,JavaScript最初是由Netscape公司开发的(当年浏览器的霸主)。JavaScript最初的名字是 LiveScript,Netscape将其命名为 JavaScript,无非是蹭 Java流量。当

    2024年04月16日
    浏览(49)
  • JavaScript原型链污染

    在浏览某个论坛的时候,第一次看到了JavaScript原型链污染漏洞。当时非常的好奇,当时我一直以为js作为一种前端语言,就算存在漏洞也是针对前端,不会危害到后端,因此我以为这种漏洞危害应该不大。可当我看到他的漏洞危害还有可以执行任意命令的时候,发现可能我想

    2024年02月10日
    浏览(40)
  • 【JavaScript】原型

    在 JavaScript 中,每个对象都有一个原型(prototype),它是一个对象本身,而不是一个函数。原型机制是 JavaScript 的核心特性之一,它允许对象继承另一个对象的属性和方法。 以下是关于 JavaScript 原型的基本概念和用法: 原型链: 每个对象都有一个原型,而原型本身也是一个

    2024年02月11日
    浏览(33)
  • JavaScript原型链污染学习记录

    0 原型及其搜索机制 NodeJS原型机制,比较官方的定义: 我们创建的每个函数都有一个 prototype(原型)属性,这个属性是一个指针,指向一个对象, 而这个对象的用途是包含可以由特定类型的所有实例共享的属性和方法 设计原型的初衷无非是对于每个实例对象,其拥有的共同

    2024年02月02日
    浏览(44)
  • JavaScript原型链污染漏洞复现与防范

    目录 什么是原型链污染漏洞? 复现原型链污染漏洞 防范原型链污染漏洞 原型链污染是JavaScript中的一种安全漏洞,利用该漏洞可以修改对象的原型,从而影响对象及其属性的行为。攻击者可以通过修改原型链来添加或覆盖属性,甚至在全局范围内添加恶意代码,导致应用程

    2024年02月13日
    浏览(41)
  • JavaScript 原型链解析,宏任务和微任务

      目录 什么是原型链? 原型与构造函数 原型链的工作原理 实例:理解原型链 宏任务(Macro Task) 微任务(Micro Task) JavaScript 是一门基于原型的语言,而原型链是 JavaScript 中实现继承的一种机制。它允许对象通过从其他对象继承属性和方法,形成一个链式结构。当访问一个

    2024年02月14日
    浏览(26)
  • 建站系列(五)--- 前端开发语言之HTML、CSS、JavaScript

    建站系列(一)— 网站基本常识 建站系列(二)— 域名、IP地址、URL、端口详解 建站系列(三)— 网络协议 建站系列(四)— Web服务器之Apache、Nginx 建站系列(五)— 前端开发语言之HTML、CSS、JavaScript 建站系列(六)— 后端开发语言 建站系列(七)— 常用前后端框架

    2024年02月09日
    浏览(52)
  • 第4集丨JavaScript 使用原型(prototype)实现继承——最佳实战2

    书接上集,在上集中我们给出了一个需求说明,要求利用现学的知识实现原型( prototype )继承,并且我们给出了三种实现方式。但是这三种方式各自有优缺点,都不能很好的满足要求,那是否还有其他更好的实现方式呢? 在看本文之前,诸位可以自己思考下?带着问题去学

    2024年02月12日
    浏览(45)
  • 第2集丨JavaScript 中原型链(prototype chain)与继承

    对于使用过基于类的语言(如 Java 或 C++ )的开发者来说, JavaScript 实在是有些令人困惑—— JavaScript 是动态的且没有静态类型。一切都是对象(实例)或函数(构造函数),甚至函数本身也是 Function 构造函数的实例。即使是语法结构中的“类”也只是运行时的构造函数。

    2024年02月12日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包