JavaScript的数据类型及检测方式

news2025/1/6 13:41:10

目录

一、JS数据类型

1.基本数据类型

2.引用数据类型

二、堆和栈

三、数据类型检测

1.typeof

2.instanceof

3.constructor

4.Object.prototype.toString.call()


JavaScript 中的数据类型主要分为两大类:原始数据类型(也称基本数据类型)和引用数据类型。

一、JS数据类型

1.基本数据类型

(1)Undefined未定义

类型只有一个值,即undefined

在使用var声明变量,但未对其加以初始化时,这个变量值就是undefined

(2)Null空对象

类型只有一个值的数据类型,其特殊值就是null

从逻辑角度上看,null是一个空的对象指针,表示一个空值或者没有值。

(3)Boolean

布尔类型,有两个值:truefalse

需要注意的是,布尔类型的字面值truefalse是区分大小写的。

(4)Number

数字类型,有两种表示方法:整数和浮点数。例如:423.14159

整数可以通过十进制、八进制、十六进制的字面值来表示。

浮点数必须包含一个小数点,且小数点后必须有一位数字。

(5)String

字符串类型,用于表示文本数据或字符序列。例如:"Hello, World!"

可以用单引号或双引号来表示,注意成对出现。

(6)Symbol

符号类型是ECMAScript 6版新定义的。

符号类型是唯一的并且是不可修改的,通常用于对象属性的键。例如:Symbol('myKey')

Symbol函数前不能使用new命令,否则会报错。

(7)BigInt

表示任意精度的整数。用于表示大于 2^53 - 1 的整数。例如:123n

2.引用数据类型

(1)Object

对象类型,是一组数据和功能(函数)的集合。它可以包含其他的数据类型(包括原始类型和对象类型),以及方法(函数)。例如:{name: 'Alice', age: 25}

(2)Array

数组类型,表示一个有序的集合。例如:[1, 2, 3]

数组可以使用索引来访问其元素。

(3)Function

函数类型,表示一个可执行的操作。例如:function add(a, b) { return a + b; }

在JavaScript中,函数也是对象,因此它们可以拥有属性和方法。

(4)Date

日期类型,表示日期和时间。例如:new Date()

提供了多种方法来操作和格式化日期和时间。

(5)RegExp(正则表达式)

用于匹配文本的模式,通常用于文本搜索和“查找替换”文本操作。例如:/ab+c/i

在处理字符串和文本时非常有用。

二、堆和栈

栈:原始数据类型

堆:引用数据类型

两种类型的区别在于存储位置的不同:

原始数据类型直接存储在栈中的简单数据段,占据空间小、大小固定,属于被频繁使用数据,所以放入栈中存储;

引用数据类型存储在堆中的对象,占据空间大,大小不固定。

三、数据类型检测

1.typeof

typeof 运算符是用于检测变量数据类型的常用方法。尽管它非常有用,但有一些限制和特殊情况需要注意。

console.log(typeof undefined); // undefined

console.log(typeof 0); // number

console.log(typeof true); // boolean

console.log(typeof "hello"); // string

console.log(typeof Symbol()); // symbol

const bigIntNum = 9007199254740991n;

console.log(typeof bigIntNum); // bigint

function foo() {}

console.log(typeof foo); // function

其中数组、对象、null都会被判断为object,其他判断都正确。

console.log(typeof null); // // object

console.log(typeof []); // object

console.log(typeof {}); // object

2.instanceof

instanceof 运算符用于检测一个对象是否是另一个构造函数的实例。这个运算符非常有用,尤其是在处理对象和数组时,因为 typeof 运算符对它们都返回 "object",这使得 instanceof 成为区分它们的有效工具。但是instanceof只能正确判断引用数据类型,而不判断基本数据类型。

const obj = {};

console.log(obj instanceof Object); // true

const arr = [];

console.log(arr instanceof Array); // true

console.log(2 instanceof Number); // false

3.constructor

constructor有两个作用,一是判断数据的类型,二是对象实例通过constructor对象访问它的构造函数。如果创建一个对象来改变它的原型,constructor就不能用来判断数据类型了。

console.log({}.constructor === Object); // true

console.log([].constructor === Array); // true

console.log(function(){}.constructor === Function); // true

console.log((2).constructor === Number); // true

console.log(('str').constructor === String); // true

// 如果创建一个对象来改变它的原型,constructor就不能用来判断数据类型了。

function myFn(){};

myFn.prototype=new Array();

var f = new myFn();

console.log(f.CONSTRUCTOR===myFn); // false

console.log(f.constructor===Array); // true

4.Object.prototype.toString.call()

Object.prototype.toString.call()使用Object对象的原型方法toSting来判断数据类型。

console.log(Object.prototype.toString.call(42)); // "[object Number]"

console.log(Object.prototype.toString.call("Hello")); // "[object String]" console.log(Object.prototype.toString.call(true)); // "[object Boolean]" console.log(Object.prototype.toString.call({})); // "[object Object]" console.log(Object.prototype.toString.call([])); // "[object Array]" console.log(Object.prototype.toString.call(null)); // "[object Null]" console.log(Object.prototype.toString.call(undefined));// "[object Undefined]"

这些方法可以结合使用,以覆盖 typeof 的不足,提供更全面和准确的数据类型检测。

记录

若文章对你有帮助,点赞、收藏加关注吧!

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

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

相关文章

电脑中缺失的nvrtc64_90.dll文件如何修复?

一、文件丢失问题 案例:nvrtc64_90.dll文件缺失 问题分析: nvrtc64_90.dll是NVIDIA CUDA Runtime Compilation库的一部分,通常与NVIDIA的CUDA Toolkit或相关驱动程序一起安装。如果该文件丢失,可能会导致基于CUDA的应用程序&…

GIT 企业级开发学习 1

本节主要命令: git init ls 不能列出 .git ls -a 列出 .git 1. 初始化 Git 仓库 git init • 初始化一个新的 Git 仓库,在当前目录下生成一个 .git 隐藏文件夹,用于存储版本控制信息。 2. 查看隐藏文件 ls -a • 使用 ls -a 显示隐藏文件…

用Tkinter制作一个用于合并PDF文件的小程序

需要安装PyPDF2库,具体原代码如下: # -*- coding: utf-8 -*- """ Created on Sun Dec 29 14:44:20 2024author: YBK """import PyPDF2 import os import tkinter as tk import windndpdf_files [] def dragged_files(f…

蓝桥杯JAVA--003

需求 2.代码 public class RegularExpressionMatching {public boolean isMatch(String s, String p) {if (p.isEmpty()) {return s.isEmpty();}boolean firstMatch !s.isEmpty() && (s.charAt(0) p.charAt(0) || p.charAt(0) .);if (p.length() > 2 && p…

接口开发完后,个人对于接下来接口优化的一些思考

优化点 入参的合法性和长度范围&#xff0c;必填项的检查验证 因为没有入参&#xff0c;所以不需要考虑。 批量思想解决N1问题 // 假设要查询100个订单及其对应的用户信息 List<Order> orders orderMapper.selectList(new QueryWrapper<>().last("limit …

C403 unity打开方法

1 unity hub右键以管理员方式打开。 2 注册登录账户 如果出现 如果还是不行&#xff0c;把地址栏的网址复制&#xff0c;在google浏览器中打开 如果出现安全策略&#xff0c;就不勾选安全防护 尝试方案1 把unityhub在任务管理器中关闭 如果验证码发送成功&#xff0c;还是进不…

linux-25 文件管理(三)复制、移动文件,cp,mv

命令cp是copy的简写&#xff0c;而mv则是move的简写。那既然copy是用于实现复制文件的&#xff0c;那通常一般我们要指定其要复制的是谁&#xff1f;而且复制完以后保存在什么地方&#xff0c;对吧&#xff1f;那因此它的使用格式很简单&#xff0c;那就是cp srcfile dest&…

『 Linux 』高级IO (二) - 多路转接

文章目录 前情提要新连接的获取新连接的添加不同事件的处理select 的缺点poll( )SelectServer 改为 PollServer Epoll多路转接方案Epoll 原理深入了解Epoll接口Epoll的优势 select( )/poll( )完整代码(供参考) 前情提要 在博客『 Linux 』高级IO (一)中介绍了五种IO模型; 阻塞式…

基于微信小程序的自修室预约系统

目录 一、前言 二、技术介绍 三、系统实现 四、核心代码 五、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。 一、前言 在知识爆炸的时代&#xff0c;自修室成为了众多学习者…

CPO-CNN-GRU-Attention、CNN-GRU-Attention、CPO-CNN-GRU、CNN-GRU四模型多变量时序预测对比

CPO-CNN-GRU-Attention、CNN-GRU-Attention、CPO-CNN-GRU、CNN-GRU四模型多变量时序预测对比 目录 CPO-CNN-GRU-Attention、CNN-GRU-Attention、CPO-CNN-GRU、CNN-GRU四模型多变量时序预测对比预测效果基本介绍程序设计参考资料 预测效果 基本介绍 基于CPO-CNN-GRU-Attention、…

ctfshow 每日练习 web 区 php特性 1-10

前置知识 这个php特性可以很好的练习我们的白盒简单代码的审计能力 web89 preg_match 正则匹配函数 &#xff08;绕过 &#xff1a; 换行符绕过 &#xff08;也可以利用他的数组返回数字进行绕过一下禁止字符的情况&#xff09;&#xff09; include("flag.php&q…

单元测试入门和mockup

Java 新手入门&#xff1a;Java单元测试利器&#xff0c;Mock详解_java mock-CSDN博客 这个是典型的before when assert三段式&#xff0c;学一下单测思路 这个没有动态代理&#xff0c;所以是直接class(对比下面) Jmockit使用笔记_增加代码覆盖率_覆盖try catch_使用new Mock…

使用Docker部署最新版JupyterHub

拉取镜像 docker pull jupyterhub/jupyterhub:latest启动镜像 docker run -d -p 8000:8000 --name jupyterhub jupyterhub/jupyterhub:latest jupyterhub进入容器 docker exec -it jupyterhub bash生成jupyterhub的配置文件 jupyterhub --generate-config# 有需要可以安装中…

MySQL 01 02 章——数据库概述与MySQL安装篇

一、数据库概述 &#xff08;1&#xff09;为什么要使用数据库 数据库可以实现持久化&#xff0c;什么是持久化&#xff1a;数据持久化意味着将内存中的数据保存到硬盘上加以“固化”持久化的主要作用是&#xff1a;将内存中的数据存储在关系型数据库中&#xff0c;当然也可以…

OLED的显示

一、I2C I2C时序&#xff1a;时钟线SCL高电平下&#xff1a;SDA由高变低代表启动信号&#xff0c;开始发送数据&#xff1b;SCL高电平时&#xff0c;数据稳定&#xff0c;数据可以被读走&#xff0c;开始进行读操作&#xff0c;SCL低电平时&#xff0c;数据发生改变&#xff1…

Java高频面试之SE-08

hello啊&#xff0c;各位观众姥爷们&#xff01;&#xff01;&#xff01;本牛马baby今天又来了&#xff01;哈哈哈哈哈嗝&#x1f436; 成员变量和局部变量的区别有哪些&#xff1f; 在 Java 中&#xff0c;成员变量和局部变量是两种不同类型的变量&#xff0c;它们在作用域…

3blue1brow线代笔记

向量 物理&#xff1a;空间中的箭头&#xff0c;长度和方向决定一个向量。只要两者相同&#xff0c;可以任意移动保持不变 计算机&#xff1a;有序的数字列表 &#xff08;数组&#xff09; 数学&#xff1a;向量可以是任何东西&#xff0c;只要保证两个向量相加以及数字与向量…

开源的Vue低代码表单设计器 form-create-designer v3.2.9 版本发布,新增10多种功能

form-create-designer 是一款开源的低代码表单设计器&#xff0c;通过数据驱动表单渲染。可以通过拖拽的方式快速创建表单&#xff0c;提高开发者对表单的开发效率&#xff0c;节省开发者的时间。并广泛应用于在政务系统、OA系统、ERP系统、电商系统、流程管理等领域。 项目采…

告别编程困惑:GDB、冯诺依曼、操作系统速通指南

&#x1f31f; 快来参与讨论&#x1f4ac;&#xff0c;点赞&#x1f44d;、收藏⭐、分享&#x1f4e4;&#xff0c;共创活力社区。&#x1f31f; &#x1f6a9;用通俗易懂且不失专业性的文字&#xff0c;讲解计算机领域那些看似枯燥的知识点&#x1f6a9; 目录 前言 一…

Jenkins 中自动化部署 Spring Boot 项目

&#x1f468;&#x1f3fb;‍&#x1f4bb; 热爱摄影的程序员 &#x1f468;&#x1f3fb;‍&#x1f3a8; 喜欢编码的设计师 &#x1f9d5;&#x1f3fb; 擅长设计的剪辑师 &#x1f9d1;&#x1f3fb;‍&#x1f3eb; 一位高冷无情的全栈工程师 欢迎分享 / 收藏 / 赞 / 在看…