【JavaScript】原型与原型链以及判断数据类型方式

news2024/9/25 11:12:59

💻 【JavaScript】原型与原型链以及判断数据类型方式 🏠专栏:JavaScript
👀个人主页:繁星学编程🍁
🧑个人简介:一个不断提高自我的平凡人🚀
🔊分享方向:目前主攻前端,其他知识也会阶段性分享🍀
👊格言:☀️没有走不通的路,只有不敢走的人!☀️
👉让我们一起进步,一起成为更好的自己!!!🎁

文章目录

  • 【JavaScript】原型与原型链以及判断数据类型方式
    • 一. 原型(prototype)
    • 二. 原型链
    • 三. 判断数据类型

【JavaScript】原型与原型链以及判断数据类型方式

一. 原型(prototype)

将公共的方法提取出来,都写在原型上(只用书写和创建一次)

在内置构造函数的原型上扩展一个新方法,所有的数组都可以使用这个方法

Array.prototype.getMin = function () {
    min = Math.min(...this); // this指向arr
    return min;
}
const arr = [4, 23, 34, 11, 435];
console.log(arr.getMin()); // 4

原型概念

每一个函数:天生自带一个属性 prototype(对象数据类型
每一个对象:天生自带一个属性 __proto__(指向所属构造函数的原型)

实例化对象

  • const p = new Person();
  • p 是 Person的实例对象
  • p 的构造函数是 Person
  • p 的 __proto__ 指向 Person.prototype

JS中内置的构造函数

  • Object
  • Array
  • Date
  • RegExp
  • Function
// eg:
const obj = new Object()
const arr = new Array()
//  任何一个数组,所属的构造函数是 Array
//  任何一个对象,所属的构造函数是 Object

用数组为例

  • 任何一个数组,所属的构造函数都是Array
  • Array原型上的方法,都是给数组使用

一切皆对象

  • 只要是 [] 所属的构造函数就是Array
  • 只要是 {} 所属的构造函数就是Object
  • 只要是 function () {} 所属的构造函数就是Function

问答?

  1. 原型是什么 ?

    一个对象,我们也称为 prototype 为原型对象。

  2. 原型的作用是什么 ?

    共享方法。

  3. 为什么要使用原型对象

    因为构造函数方法虽然很好用,但是存在浪费内存的问题。每一次调用构造函数中的方法都会重新开辟一块新的内存存储(浪费了空间),而原型对象(prototype)可以对象共享可以节省内存。

二. 原型链

原型链:使用__proto__串联起来的链状结构

对象的访问机制

  • 当访问一个对象成员的时候
    • 首先在该对象自己身上查找,如果有直接使用,停止查找
    • 如果没有,会自动去到__proto__查找,如果有直接使用,停止查找
    • 如果仍然没有,继续去到__proto__在上一级查找
    • 如果没有找到,返回undefined, (找到了原型链的顶级 null)

官方:每个实例对象(object)都有一个私有属性(称之为 proto)指向它的构造函数的原型对象(prototype)。该原型对象也有一个自己的原型对象(proto),层层向上直到一个对象的原型对象为 null。根据定义,null 没有原型,并作为这个原型链中的最后一个环节。

function Person() {
    this.name = 'tom'
    this.age = 18
}
const p = new Person()
/*
  七个指向问题:(p ==> Person的实例对象)
  	寻找思路主要还是要先了解:该对象所属的构造函数是什么?
  		1.p.__pro__                     ==> Person.prototype
  		2.Person.prototype.__proto__    ==> Object.prototype
  		3.Person.__proto__              ==> Function.prototype
  		4.Function.__proto__            ==> Function.prototype
  		5.Object.__proto__              ==> Function.prototype
  		6.Function.prototype.__proto__  ==> Object.prototype
  		7.Object.prototype.__proto__    ==> null

   所以以下等式结果全为true
        p.__proto__ === Person.prototype
        Person.prototype.__proto__ === Object.prototype
        Person.__proto__ === Function.prototype
        Function.__proto__ === Function.prototype
        Object.__proto__ === Function.prototype
        Function.prototype.__proto__ === Object.prototype
        Object.prototype.__proto__ === null
        */

原型链指向图

请添加图片描述

三. 判断数据类型

判断数据类型的方式

  1. typeof

    语法:typeof(要测试的数据)
    返回值:测试数据对应的数据类型
    缺点:只能检测 基本数据类型

    console.log(typeof (12)); // number
    console.log(typeof ('null')); // string
    console.log(typeof (null)); // object
    console.log(typeof (undefined)); // undefined
    console.log(typeof (true)); // boolean
    console.log(typeof ([])); // object
    console.log(typeof ({})); // object
    
  2. constructor

    语法:数据结构.constructor
    返回值:该数据结构所属的构造函数
    缺点:无法检测 undefined 和 null

    console.log([].constructor); // ƒ Array() { [native code] }
    console.log({}.constructor); // ƒ Object() { [native code] }
    console.log(function () { }.constructor); // ƒ Function() { [native code] }
    console.log((1).constructor); // ƒ Number() { [native code] }
    console.log(('zs').constructor); // ƒ String() { [native code] }
    console.log((null).constructor); // Uncaught TypeError: Cannot read properties of null (reading 'constructor')
    console.log((undefined).constructor); // Uncaught TypeError: Cannot read properties of undefined (reading 'constructor')
    
  3. instanceof

    语法:数据结构 instanceof 构造函数
    返回值:true/false
    缺点:无法检测 undefined 和 null

    console.log([] instanceof Array); // true
    console.log([] instanceof Object); // true
    console.log([] instanceof String); // false
    console.log(null instanceof Object); // false
    console.log(undefined instanceof Object); // false
    let a = 1;
    console.log(a instanceof Number); // false
    
  4. Object.prototype.toString.call()

    语法:Object.prototype.toString.call(要测试的数据)
    返回值:‘[Object 数据类型]’
    所有数据类型都可以检测

    console.log(Object.prototype.toString.call(1)); // [object Number]
    console.log(Object.prototype.toString.call([])); // [object Array]
    console.log(Object.prototype.toString.call({})); // [object Object]
    console.log(Object.prototype.toString.call(true)); // [object Boolean]
    
    console.log(Object.prototype.toString.call(123)); // [object Number]
    console.log(Object.prototype.toString.apply(123)); // [object Number]
    console.log(Object.prototype.toString.bind(123)()); // [object Number]
    

    :不必一定用call()也可以使用bind()()apply(),只要是立即执行即可。

结束语

希望对您有一点点帮助,如有错误欢迎小伙伴指正。
👍点赞:您的赞赏是我前进的动力!
⭐收藏:您的支持我是创作的源泉!
✍评论:您的建议是我改进的良药!
一起加油!!!💪💪💪

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

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

相关文章

Redis对不起是我肤浅了(基础和应用篇):位图(Bitmaps)的妙用和深入分析每个命令的用法

一、前言 在Redis 4.0 版本之前,Redis是单线程程序,主要是指Redis的网络I/O线程。Redis的持久化、集群同步等操作,则是由另外的线程来执行的。但在Redis 4.0 版本之后,Redis添加了多线程的支持,这时的多线程主要体现在…

【IT互联网行业内,什么岗位工作更有前景?】

前言互联网及IT行业作为集技术与高薪于一身的新技术行业,不仅成为时下众多年轻人的首选行业,其本身也承载了社会、企业数字化发展转型的重担,从国家到社会、市场都非常重视行业技术的发展和渗透,其重要性不言而喻。作为普通人的小…

AcWing 1073. 树的中心(详解树形DP和换根DP)

AcWing 1073. 树的中心(树形DP 换根DP)一、问题二、思路1、暴力做法2、树形DP换根DP(1)思路分析(2)普通树形DP与换根DP的区别三、代码一、问题 二、思路 1、暴力做法 这道题其实暴力的做法很简单&#x…

【金融学】Economics of Money and Banking {暂时搁置,中级宏观和微观经济学未学}

Economics of Money and BankingClass1 The Big PicturePrerequisitesSome MaterialsCourse Material: https://www.coursera.org/learn/money-banking/lecture/8WXSW/the-big-picture Class1 The Big Picture Prerequisites intermediate macroeconomics 中级宏观经济学 int…

Java on VS Code 2023年1月更新|Spring 插件包、代码补全更新以及性能改进

作者:Nick Zhu - Senior Program Manager, Developer Division at Microsoft 排版:Alan Wang 大家好,欢迎来到我们 2023 年的第一篇博客!我们想与您分享几个与 Spring 插件、代码编辑和性能相关的激动人心的更新,让我们…

XML方式—解决mybatis实体类属性名和数据库字段名不一致问题

数据库字段与类属性名称不一致&#xff0c;导致查询数据时数据没有封装上。 [Brand{id1, brandNamenull, companyNamenull}, Brand{id2, brandNamenull, companyNamenull}]解决方式一&#xff08;为表字段取别名&#xff09; <select id"selectAll" resultType&…

【大唐杯备考】——5G网络组网部署(学习笔记)

&#x1f4d6; 前言&#xff1a;本期介绍5G网络组网部署。 目录&#x1f552; 1. SA组网和NSA组网&#x1f558; 1.1 SA组网&#x1f558; 1.2 NSA组网&#x1f564; 1.2.1 Option 3系列&#x1f564; 1.2.2 Option 7系列&#x1f564; 1.2.3 Option 4系列&#x1f558; 1.3 组…

【Linux】gcc编译器

【Linux】gcc编译器 文章目录【Linux】gcc编译器1、背景2、翻译过程2.1 预处理2.2 编译2.3 汇编2.4 链接2.5 总过程3、动、静态链接库3.1 查看库3.2 库分类3.3 链接使用4、gcc参数总结1、背景 在Linux中&#xff0c;C语言的编译肯定需要编译器来进行&#xff0c;这个编译器就是…

微课录制软件哪个好用?微课制作方法分享

很多小伙伴都不知道什么是微课&#xff1f;微课视频时长比较短&#xff0c;一般在5-10分钟。微课的教学内容也比较少&#xff0c;一个微课视频一般只对一个知识点进行针对性讲解。微课的这些特性可以让我们利用碎片时间进行学习。制作微课需要录制电脑屏幕&#xff0c;那微课录…

Python 部分位运算(包含负数反码手算求法)

首先要回忆负数的补码的求法&#xff1a;写出其相反数的原码&#xff0c;而后从右往左&#xff0c;碰到第一个1后上面的数全取反。 下面以4位二进制的-5举例&#xff08;首位为符号位&#xff09;&#xff1a; 5的原码 0101末位遇1后取反 1011即-5的补码为 1011下面是部分pytho…

C/C++ 高精度(加减乘除)算法压位优化

文章目录前言一、基本原理1、存储方式2、计算方式二、完整代码三、性能对比总结附录1、性能测试代码前言 由于上一章《C/C 高精度&#xff08;加减乘除&#xff09;算法简单实现》实现了基本的高精度计算&#xff0c;数组的每个元素存储一位10进制的数字。这样的存储方式并不是…

数学建模学习笔记(15)时间序列分析

时间序列分析时间序列分析概述和数据预处理时间序列分解模型指数平滑模型ARIMA模型时间序列分析概述和数据预处理 时间序列的概念&#xff1a;也称为动态序列&#xff0c;是指将某种现象的指标值按照时间顺序排列而成的数值序列。 时间序列的组成要素&#xff1a;时间要素、数…

表格控件Aspose.Cells for Java 授权须知

Aspose API支持流行文件格式处理&#xff0c;并允许将各类文档导出或转换为固定布局文件格式和最常用的图像/多媒体格式。 Aspose.Cells for Java 是一个屡获殊荣的Excel电子表格处理API&#xff0c;它允许Java开发人员在自己的Java应用程序中嵌入可读取、写入和操作Excel电子…

天云数据Hubble数据库被评为“IDC创新者:中国分布式数据库,2022”

近日&#xff0c;国际知名研究机构 IDC 发布《IDC Innovator&#xff1a;中国分布式关系型数据库》报告正式发布&#xff0c;天云融创数据科技&#xff08;北京&#xff09;有限公司&#xff08;以下简称“天云数据”&#xff09;被评为“IDC创新者&#xff1a;中国分布式数据库…

经过ASEMI整流桥MB10F后输出电压是多少

编辑-Z 型号&#xff1a;MB10F 封装&#xff1a;MBF-4 最大重复峰值反向电压&#xff08;VRRM&#xff09;&#xff1a;1000V 最大平均正向整流输出电流&#xff08;IF&#xff09;&#xff1a;1.0A 峰值正向浪涌电流&#xff08;IFSM&#xff09;&#xff1a;35A 每个元…

清楚姐姐玩翻翻乐[期望dp]

首先这肯定是个期望dp。 首先明确二点 1.一旦这张牌已经知道数字了&#xff0c;下次翻他肯定是给他配对 2.如果已经知道了两张相同数字的卡片&#xff0c;那么在之后什么时候翻面都不会影响操作次数 故dp状态只需要记录只知道一张的卡片数量和未知的卡片数量。 接下来一个问题就…

多微网优化调度(风机、光伏、蓄电池、燃料电池、柴油机、电网交互)(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

【c语言进阶】文件操作(上)

&#x1f680;write in front&#x1f680; &#x1f4dc;所属专栏&#xff1a;> c语言学习 &#x1f6f0;️博客主页&#xff1a;睿睿的博客主页 &#x1f6f0;️代码仓库&#xff1a;&#x1f389;VS2022_C语言仓库 &#x1f3a1;您的点赞、关注、收藏、评论&#xff0c;是…

【C++11新特性】| 并发编程

文章目录一、std::thread1.1 成员函数1.2 案例二、std::mutex三、std::lock3.1 lock_guard3.2 unique_lock3.3 lock_guard与unique_lock的对比四、std::atomic五、volatile六、condition_variable成员函数七、future、promise、packaged_task7.1 std::promise7.2 std::future7.…

【Cloudcone】VPS 登录、防火墙设置

服务器登录、防火墙设置本来是一件很简单的事情&#xff0c;但是我买了国外服务器&#xff0c;有些地方出现了一些问题。 文章目录一、简介二、使用ipv6登录服务器三、防火墙设置四、小插曲一、简介 我一直用的腾讯云的服务器&#xff0c;但是带宽太低了&#xff0c;只有4M。最…