• JS中原型相关的十个知识点总结


    JavaScript 中的原型(Prototype)是理解对象和继承机制的核心概念。以下是我对 JavaScript 原型相关知识点的总结和详细讲解:

    1. 原型对象(Prototype Object)

    在 JavaScript 中,每个对象都有一个关联的对象,这个关联的对象称为“原型”。当你尝试访问一个对象的属性时,如果该对象本身没有这个属性,JavaScript 引擎会沿着原型链向上查找,直到找到这个属性或到达原型链的末尾(即 null)。

    2. __proto__ 属性

    每个 JavaScript 对象都有一个 __proto__ 属性,这个属性指向对象的原型。这个属性通常不建议直接使用,但它是理解原型链的关键。__proto__ 不是标准的一部分,它更像是为了方便调试和学习而存在。

    例如:

    let obj = {};
    console.log(obj.__proto__); // 输出 Object.prototype
    

    3. prototype 属性

    prototype 属性是函数对象(即构造函数)的属性,用于指定当通过这个构造函数创建新对象时,新对象的原型。

    function Person(name) {
        this.name = name;
    }
    
    Person.prototype.sayHello = function() {
        console.log('Hello, ' + this.name);
    };
    
    let person1 = new Person('Alice');
    person1.sayHello(); // 输出 "Hello, Alice"
    

    在上面的代码中,Person 是一个构造函数,Person.prototype 是其原型对象。通过 new Person() 创建的 person1 对象的原型就是 Person.prototype

    4. 构造函数与实例的关系

    当使用构造函数创建一个新对象时,这个对象的 __proto__ 属性会被设置为构造函数的 prototype 属性。

    let person2 = new Person('Bob');
    console.log(person2.__proto__ === Person.prototype); // 输出 true
    

    5. 原型链(Prototype Chain)

    JavaScript 对象可以通过原型链来继承属性和方法。每个对象都有一个原型,而这个原型本身也是一个对象,也有它自己的原型。这样就形成了一条原型链。

    console.log(person1.__proto__); // Person.prototype
    console.log(person1.__proto__.__proto__); // Object.prototype
    console.log(person1.__proto__.__proto__.__proto__); // null
    

    当访问 person1 对象的某个属性时,JavaScript 会首先查找 person1 对象本身是否具有这个属性;如果没有,它会继续查找 person1.__proto__,即 Person.prototype;如果还没有,就会继续查找 Object.prototype,最后到达 null,即原型链的终点。

    6. Object.create() 方法

    Object.create() 方法可以创建一个新对象,使用现有的对象作为新对象的原型。

    let proto = {
        greet() {
            console.log('Hello!');
        }
    };
    
    let obj = Object.create(proto);
    obj.greet(); // 输出 "Hello!"
    

    在这个例子中,obj 的原型是 proto 对象,所以 obj 可以访问 proto 中定义的 greet 方法。

    7. instanceof 操作符

    instanceof 操作符用于判断一个对象是否是某个构造函数的实例,它会沿着原型链向上查找,直到找到匹配的原型或到达 null

    console.log(person1 instanceof Person); // 输出 true
    console.log(person1 instanceof Object); // 输出 true
    

    8. hasOwnProperty 方法

    hasOwnProperty 是 JavaScript 对象的一个方法,用于判断某个属性是否为对象本身的属性(而不是从原型链继承的)。

    console.log(person1.hasOwnProperty('name')); // 输出 true
    console.log(person1.hasOwnProperty('sayHello')); // 输出 false
    

    9. 原型的动态性

    因为 JavaScript 中的原型是动态的,所以可以在运行时修改原型或给原型添加属性和方法,这些变化会立即反映在所有基于这个原型的对象上。

    Person.prototype.sayGoodbye = function() {
        console.log('Goodbye, ' + this.name);
    };
    
    person1.sayGoodbye(); // 输出 "Goodbye, Alice"
    

    10. ES6 中的 class 语法糖

    ES6 引入了 class 语法糖,用于更简洁地创建对象和处理继承,但它依然是基于原型的。

    class Animal {
        constructor(name) {
            this.name = name;
        }
    
        speak() {
            console.log(this.name + ' makes a noise.');
        }
    }
    
    let animal = new Animal('Dog');
    animal.speak(); // 输出 "Dog makes a noise."
    

    尽管 class 语法看起来像传统面向对象编程中的类,但它只是对原型继承的封装和简化。

    总结

    理解 JavaScript 中的原型及其相关概念(如原型链、prototype 属性、__proto__instanceof 等)对于掌握 JavaScript 的对象继承和代码复用非常重要。通过这些机制,JavaScript 提供了灵活而强大的对象创建和继承模型。

  • 相关阅读:
    VUEX的基础使用存值及异步
    【开源】JAVA+Vue.js实现天沐瑜伽馆管理系统
    Android 进程数据库更新时机
    【第3节】“茴香豆“:搭建你的 RAG 智能助理
    nuScenes数据集浅探(待完善……)
    docker安装Elasticsearch
    MySQL user权限表详解
    UNITY2022打包window无法窗口化的问题
    【前端异常】JavaScript错误处理:分析 Uncaught(in promise) error
    Java Object类方法简要解释(equals, hashCode, toString, finalize)
  • 原文地址:https://blog.csdn.net/2301_79858914/article/details/141070959