【JavaScript】29_原型对象

简介: # 11、原型对象访问一个对象的原型对象对象.__proto__Object.getPrototypeOf(对象)原型对象中的数据:1. 对象中的数据(属性、方法等)2. constructor (对象的构造函数)注意:原型对象也有原型,这样就构成了一条原型链,根据对象的复杂程度不同,原型链的长度也不同p对象的原型链:p对象 --> 原型 --> 原型 --> nullobj对象的原型链:obj对象 --> 原型 --> null原型链:- 读取对象属性时,会优先对象自身属性, 如果对象中有,则使用,没有则去对象的原型中寻找 如果原型中有,则使用,没

11、原型对象

访问一个对象的原型对象
对象.__proto__
Object.getPrototypeOf(对象)

原型对象中的数据:

  1. 对象中的数据(属性、方法等)
  2. constructor (对象的构造函数)

注意:
原型对象也有原型,这样就构成了一条原型链,根据对象的复杂程度不同,原型链的长度也不同
p对象的原型链:p对象 --> 原型 --> 原型 --> null
obj对象的原型链:obj对象 --> 原型 --> null

原型链:

  • 读取对象属性时,会优先对象自身属性,
    如果对象中有,则使用,没有则去对象的原型中寻找
    如果原型中有,则使用,没有则去原型的原型中寻找
    直到找到Object对象的原型(Object的原型没有原型(为null))

    如果依然没有找到,则返回undefined
    
  • 作用域链,是找变量的链,找不到会报错
  • 原型链,是找属性的链,找不到会返回undefined
    <script>
            class Person {
                name = "孙悟空"
                age = 18

                sayHello() {
                    console.log("Hello,我是", this.name)
                }
            }
            const p = new Person()
        const obj = {} // obj.__proto__
    </script>

​ 所有的同类型对象它们的原型对象都是同一个,

​ 也就意味着,同类型对象的原型链是一样的

​ 原型的作用:

​ 原型就相当于是一个公共的区域,可以被所有该类实例访问,

​ 可以将该类实例中,所有的公共属性(方法)统一存储到原型中

​ 这样我们只需要创建一个属性,即可被所有实例访问

​ JS中继承就是通过原型来实现的,

​ 当继承时,子类的原型就是一个父类的实例

​ 在对象中有些值是对象独有的,像属性(name,age,gender)每个对象都应该有自己值,

​ 但是有些值对于每个对象来说都是一样的,像各种方法,对于一样的值没必要重复的创建

​ 尝试:

​ 函数的原型链是什么样子的?

​ Object的原型链是什么样子的?

    <script>
        class Person {
            name = '孙悟空'
            age = 18

            sayHello() {
                console.log('Hello ,我是',this.name)
            }
        }

        class Dog {}

        const p = new Person()
        const p2 = new Person()

        p.sayHello = 'hello'

        const d = new Dog()
        const d2 = new Dog()

        console.log(p)
        console.log(p2)
        console.log(p.__proto__ === p2.__proto__)


        class Animal {

        }

        class Cat extends Animal{

        }

        class TomCat extends Cat {

        }

        // TomCat --> cat --> Animal实例 --> object --> Object原型 --> null

        // cat --> Animal实例 --> object --> Object原型 --> null
        // p对象 --> object --> Object原型 --> null
        const cat = new Cat()

        console.log(cat.__proto__.__proto__.__proto__.__proto__)
    </script>
相关文章
|
1月前
|
JavaScript 前端开发
JavaScript Date(日期) 对象
JavaScript Date(日期) 对象
39 2
|
8天前
|
JavaScript 前端开发
如何在 JavaScript 中使用 __proto__ 实现对象的继承?
使用`__proto__`实现对象继承时需要注意原型链的完整性和属性方法的正确继承,避免出现意外的行为和错误。同时,在现代JavaScript中,也可以使用`class`和`extends`关键字来实现更简洁和直观的继承语法,但理解基于`__proto__`的继承方式对于深入理解JavaScript的面向对象编程和原型链机制仍然具有重要意义。
|
12天前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
12天前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。
|
1月前
|
存储 JavaScript 前端开发
JavaScript 对象的概念
JavaScript 对象的概念
37 4
|
1月前
|
缓存 JavaScript 前端开发
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
JavaScript中数组、对象等循环遍历的常用方法介绍(二)
31 1
|
1月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
16 2
|
1月前
|
JavaScript 前端开发 Unix
Node.js 全局对象
10月更文挑战第5天
24 2
|
1月前
|
存储 JavaScript 前端开发
js中的对象
js中的对象
18 3
|
1月前
|
JavaScript 前端开发
JavaScript Math(算数) 对象
JavaScript Math(算数) 对象
20 4