js构造函数的prototype赋值总结

news2025/1/13 17:44:13

我们知道通过构造函数的prototype,可以生成让所有实例对象访问的通用属性和方法,下面通过代码来解释这个过程

function Person(name){
    this.name = name;
}

Person.prototype.sex = 'man'

我们定义了一个构造函数Person,然后给它的prototype添加了一个sex的属性,下面我们来看看Person的结构

console.dir(Person)

在这里插入图片描述
下面,我们来实例化一个person的对象

let person = new Person('mike')
console.dir(person)

在这里插入图片描述

上面的结构我们看的到person的原型_proto_(图片中的[[prototype]],浏览器写法的区别)指向了构造函数Person的prototype

person.__proto__ === Person.prototype // true

这里需要特别注意的一点是__proto__和prototype属性都是作为对象的一个引用,是指针,指向存储中实际存在的一个变量,当变量中的属性和方法有变化的时候__proto__和prototype都会随之改变

如果prototype指针指向新的变量的时候,prototype会有一个新的值,但是__proto__并不会改变哦,因为它的指针没有变换指向哈,还是指向原来的变量,值当然不会改变.

我们来看看是不是和我们判断一样

function Person(name){
    this.name = name;
}
Person.prototype.sex = 'man'
let person = new Person('mike')
Person.prototype = { age: 18 }
person.__proto__
//{sex: 'man', constructor: ƒ}
Person.prototype
//{age: 18} 

从上述代码看出,和我们的预判一致,下面我们多创建一些实例对象来体验一下

function Person(name){
    this.name = name;
}
Person.prototype.sex = 'man'
let person1 = new Person('mike')
Person.prototype = { age: 18 }
let person2 = new Person('lili')

下面,我们分别来看重新赋值前后,两次实例对象的区别

person1.age // undefined
person2.age //18
person1.sex // 'man'
person2.sex //undefined

所以,我们可以总结出,
1、构造函数prototype修改或者添加属性会对原实例对象产生影响
2、构造函数prototype重新赋值,不会对原实例对象产生影响,只会对修改后的实例对象有影响

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1996600.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL:复杂查询 (一)——聚合函数分组查询联合查询

目录 1、聚合查询 1.1 聚合函数 1.1.1 COUNT() 1.1.2 SUM() 1.1.3 AVG() 1.1.4 MAX(),MIN() 1.2 分组查询 1.2.1 GROUP BY子句 1.2.1.1 round() 1.2.2 HAVING 1.2.3 示例 2、联合查询 2.1 ①取相关表笛卡尔积 2.2 ②过滤无效数据 2.3 ③精简查询结果…

【数据结构】队列,你必须知道的内部原理!!!

🌞🌞🌞生活本就沉闷,但跑起来就会有风 ~~~ 前言: 🌟🌟Hello家人们,这期讲解数据结构队列的基础知识,希望你能帮到屏幕前的你。 📚️上期博客在这里&#xff1…

书生基础岛1-开发全链路

涌现能力:知识到运用的能力。 开源工具箱: 预训练: 微调: 部署: 智能体: 智能体: 知识库构建: RAG:

初识C++ · C++11(1)

目录 前言: 1 统一列表初始化 2 声明 2.1 auto 2.2 decltype 2.3 nullptr 2.4 stl的部分变化 3 右值引用和移动语义 前言: 在C11之前,C98的出现使得C看起来更像是一门独立的语言,C委员会成立后,对外宣称的是5…

神鸟云PCDN业务招募

短Z业务--支持nat0~nat4 省内调度,晚高峰 跑量9成 配置要求: 线路:单条上行30M 硬件:32线程 64内存条 240G系统盘 1G:2T固态盘单价:移动1900 电联2500 镜像下载:http://oss.download.birdicloud.com/box/Cent…

三层架构:IOCDI

三层架构 我们先看一下三层架构是什么 我们想要实现这三层架构的分离,实现一个类实现一个功能。 我们先建立一个包,然后在包下创建接口,然后再实现接口。从而实现三层架构分离。 IOC 为了实现这三层架构的分离,我们把创建类的…

协同过滤之矩阵分解算法问题详解

1、矩阵分解出现的原因 传统的协同过滤依赖用户的历史行为来推测用户对未评分商品的评分(潜在兴趣),不需要了解物品的具体属性,也不需要知道用户的具体偏好,只需要历史评分数据就可以进行推荐,存在以下问题…

Query @azure/openai with images?

题意:使用图像与azure/openai进行交互或查询 问题背景: On chat.openai.com I can upload an image and ask chatgpt a question about it, with the existing openai and azure/openai api however there doesnt seem to be a way to do this? The Ch…

QT+ffmpeg环境配置

1.新建一个qt项目 2.下载ffmpeg文件Releases BtbN/FFmpeg-Builds GitHub 3.解压后,打开qt项目地址,将ffmpeg文件复制进qt项目 4.打开新建的qt项目头文件新加入如下内容:(如有需求可按需求添加) INCLUDEPATH $$PWD/i…

【多线程-从零开始-捌】阻塞队列,消费者生产者模型

什么是阻塞队列 阻塞队里是在普通的队列(先进先出队列)基础上,做出了扩充 线程安全 标准库中原有的队列 Queue 和其子类,默认都是线程不安全的 具有阻塞特性 如果队列为空,进行出队列操作,此时就会出现阻…

114套新闻网站源码+采集规则+安装使用教程-网络公司建站资源

运行环境 PHP5.6MYSQL5.6 – 系统版本支持WindowsLinux 源码介绍 1.版权问题 本114套新闻源码均由EYOUCMS系统二次开发而成,因为系统不涉及会员功能,所以没有版权纠纷问题,客户可以一直免费使用。 2.自动采集发布 系统自身集成了网易,新…

odoo17 翻译一个小bug

odoo17 翻译一个小bug 用户界面的没译过来 标红处,但在zh_CN.po中明显已经翻译过来了,采取暴力点的,直接把base下的base.pot删除,再更新一下,可以正常显示了

【区块链+社会公益】腾讯志愿者公益平台 | FISCO BCOS应用案例

由腾讯技术公益团队主导的“公益志愿者平台”,旨在链接公益组织和志愿者。公益组织入驻平台后可以发布公 益活动、征集志愿者,志愿者可以在平台报名参加公益活动、获得公益组织和平台联合颁发的志愿服务证书。 腾讯技术公益采用了微众区块链技术对 “公…

【Linux】网络编程套接字Scoket:UDP网络编程

目录 一、了解UDP协议 二、了解端口和IP地址 三、套接字概述与Socket的概念 四、Socket的类型 五、 Socket的信息数据结构 六、网络字节序与主机字节序的互相转换 七、地址转换函数 八、UDP网络编程流程及相关函数 socket函数 bind函数 recvfrom函数 sendto函数 …

网站开发涉及到的技术内容介绍——后端PHP(2)

网站开发涉及到的技术内容介绍——后端PHP(1)https://blog.csdn.net/xiaochenXIHUA/article/details/141000752?spm=1001.2014.3001.5501 一、PHP的常用函数 1.1、PHP文件夹的常用函数 PHP的目录常用函数 序号目录常用函数说明1$_SERVER[DOCUMENT_ROOT]获取到PHP项目的根目…

C++ -- 负载均衡式在线OJ (一)

一、项目宏观结构 1.项目功能 本项目的功能为一个在线的OJ,实现类似leetcode的题目列表、在线提交、编译、运行等功能。 2.项目结构 该项目一共三个模块: comm : 公共模块compile_server : 编译与运行模块oj_server : 获取题目列表,查看题…

Spring Boot项目缺少配置文件的解决方法:IDEA

本文介绍在IntelliJ IDEA软件中,为Spring Boot项目添加配置文件的操作方法。 最近,在IntelliJ IDEA软件中新创建了一个Spring Boot项目,是通过如下图所示的方法直接新建的。 但是,随后发现这样创建的Spring Boot项目没有配置文件。…

Threejs实现鼠标控制相机+键盘控制模型+点击指定点控制模型移动

1.前言 Threejs实现鼠标控制相机功能,键盘控制模型功能,点击指定点控制模型移动功能 键盘使用WASD控制模型移动效果图: 鼠标移动可控制相机的位置控制模型移动到指定点效果图: 2.功能拆分 根据以上效果图,可以得到以下三个主要实现的功能 鼠标移动可以使相机跟随通过键…

leetcode-121-买卖股票的最佳时机

原理: 核心原理: 如果我们真的在买卖股票,我们肯定会想:如果我是在历史最低点买入就好了!该历史最低点是指卖出当天之前的历史最低点而不是全局最低点。 实现步骤: 1、初始化变量preprices[0]表示历史股…

20240809 每日AI必读资讯

乒乓球AI机器人赢了人类!正反手灵活转换,擦网球高球都能接 - 谷歌发布首个达到人类竞技水平的机器人Agent,挑战乒乓球赛场。 - 机器人通过学习大量乒乓球状态数据,掌握了正手上旋球、反手瞄准等技能,展现出高速运动…