码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • JS原型对象


    引入:我们先用构造函数来创建一个对象

    function Student(name,age,gender){
    	this.name = name;
    	this.age = age;
    	this.gender = gender;
    	this.sayName = function(){
    		console.log(this.name);
    	};
    }
    var stu = new Person("孙悟空",500,"男");
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    在构造内部创建一个sayName方法,由于构造函数每执行一次就会创建一个新的sayName方法,当创建的对象较多时,这样做不利于性能优化,所以我们考虑下面这种写法。

    function Student(name,age,gender){
    	this.name = name;
    	this.age = age;
    	this.gender = gender;
    	this.sayName = fun;
    }
    function fun(){
    	console.log(this.name);
    }
    var stu = new Person("孙悟空",500,"男");
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    将sayName方法定义在全局,就避免了上面所说的问题,这样所有实例化的对象用的都是同一个方法。但是这样做又带来了新的问题,将函数定义在全局作用域,污染了全局作用域的命名空间,而且在实际开发中将方法暴露在全局作用域也不安全。

    下面我们来引入原型的概念。
    我们创建的每一个函数,解析器都会向函数中添加一个属性prototype,这个属性对应着一个对象,这个对象就是原型对象。
    如果函数作为普通函数调用prototype没有任何作用。
    当函数以构造函数的形式调用时,它所创建的对象中都会有一个隐含的属性,指向该构造函数的原型对象,可以通过__proto__来访问该属性

    function Test1(){
    }
    function Test2(){
    }
    var test11 = new Test1();
    console.log(Test1.prototype == Test2.prototype);//false
    console.log(Test1.prototype == test11.__proto__);//true
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述

    原型对象就相当于一个公共的区域,所有同一个类的实例都可以访问到这个原型对象。所以,可以将对象中共有的内容统一设置到原型对象中。

    当我们访问对象的一个属性或方法时,它会先在对象自身中寻找,如果有则直接使用,如果没有则会去 原型对象中寻找。

    function Test1(){
    }
    function Test2(){
    }
    var test11 = new Test1();
    Test.prototype.name = "我是原型中的名字"
    console.log(test11.name);//我是原型中的名字
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述

    function Test1(){
    }
    function Test2(){
    }
    var test11 = new Test1();
    Test.prototype.name = "我是原型中的名字"
    test11.name = "我是实例中的名字";
    console.log(test11.name);//我是实例中的名字
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    在这里插入图片描述
    原型对象也是对象,所以它也有原型
    当我们使用一个对象的属性或方法时,会先在自身中寻找
    自身中如果有,则直接使用,如果没有则去原型对象中寻找,如果原型对象中有,则使用;如果没有则去原型的原型中寻找,直到找到Object对象的原型。Object对象的原型没有原型,如果在Object中依然没有找到,则返回undefined。
    在这里插入图片描述

  • 相关阅读:
    多分类交叉熵函数计算过程(包含numpy和pytorch代码实现)
    公司一般怎样筛选简历
    centos统计子目录和文件的大小并排序
    libvirt 使用UEFI 设置 edk2-ovmf
    C++:符号的作用【::(命名空间、类、结构体作用域限定符)】【:(类的继承、初始化列表、)】【A.B(A必须为对象或结构体)】【A->B(箭头左边必须为指针),A只能是指向类、结构体、联合体的指针】
    从零手写实现 nginx-25-directive map 条件判断指令
    vue3新语法糖<script setup>
    LeetCode --- 1437. Check If All 1‘s Are at Least Length K Places Away 解题报告
    攻防演练-紫队视角下的实战攻防演练组织
    面试精选:3、史上最详细的Linux精选面试题(二)
  • 原文地址:https://blog.csdn.net/weixin_44532220/article/details/127812366
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号