JavaScript 数据类型和数据结构:从基础到实践

JavaScript 作为一门动态类型语言,以其灵活性和强大的功能在前端开发中占据了重要地位。理解 JavaScript 的数据类型和数据结构是掌握这门语言的关键。本文将带你深入探讨 JavaScript 中的数据类型、数据结构以及相关的类型检查和转换。

一、原始数据类型:不可变的基础

JavaScript 的原始数据类型是不可变的,这意味着它们的值一旦创建就不能被修改。以下是 JavaScript 中的原始数据类型:

  1. undefined
    表示变量未定义或未赋值。

    let x;
    console.log(x); // undefined
  2. null
    表示一个空值或无值。

    let y = null;
    console.log(y); // null
  3. boolean
    表示逻辑值,只有 true 和 false 两种可能。

    let isTrue = true;
    let isFalse = false;
  4. number
    表示数字,包括整数和浮点数。JavaScript 使用 64 位双精度浮点数格式表示所有数字。

    let num = 42;
    let pi = 3.14;
  5. bigint
    用于表示任意精度的整数,适合处理大整数。

    let bigNum = 123456789012345678901234567890n;
  6. string
    表示文本数据,字符串是不可变的。

    let name = "JavaScript";
  7. symbol
    表示唯一的、不可变的值,通常用作对象属性的键。

    let id = Symbol("id");

二、对象类型:灵活的复杂数据结构

对象类型是可变的,可以包含多个键值对。JavaScript 中的对象类型包括:

  1. object
    表示复杂的数据结构,可以包含多个键值对。

    let person = {name: "Alice",age: 25
    };
  2. Array
    数组是一种特殊的对象,用于存储有序的元素集合。

    let fruits = ["apple", "banana", "orange"];
  3. Function
    函数也是对象,可以被调用执行代码。

    function greet() {console.log("Hello!");
    }
  4. Date
    用于处理日期和时间。

    let now = new Date();
  5. RegExp
    用于处理正则表达式。

    let regex = /ab+c/;
  6. Map 和 Set

      Map 是一种键值对的集合,键可以是任意类型。

      Set 是一种值的集合,值可以是任意类型且唯一。

    let map = new Map();
    map.set("name", "Alice");let set = new Set();
    set.add(1);
    set.add(2);
  7. WeakMap 和 WeakSet
    类似于 Map 和 Set,但键是弱引用,不会阻止垃圾回收。

    let weakMap = new WeakMap();
    let weakSet = new WeakSet();

三、类型检查:如何判断数据类型

JavaScript 提供了多种方法来检查变量的类型:

  1. typeof
    用于检查原始数据类型,返回一个字符串表示类型。

    console.log(typeof 42); // "number"
    console.log(typeof "hello"); // "string"
    console.log(typeof true); // "boolean"
    console.log(typeof undefined); // "undefined"
    console.log(typeof null); // "object" (历史遗留问题)
    console.log(typeof {}); // "object"
    console.log(typeof []); // "object"
    console.log(typeof function() {}); // "function"
  2. instanceof
    用于检查对象是否是某个构造函数的实例。

    console.log([] instanceof Array); // true
    console.log({} instanceof Object); // true
  3. Object.prototype.toString
    用于获取对象的内部 [[Class]] 属性,可以更准确地判断类型。

    console.log(Object.prototype.toString.call([])); // "[object Array]"
    console.log(Object.prototype.toString.call({})); // "[object Object]"

四、类型转换:隐式与显式

JavaScript 是弱类型语言,允许隐式和显式的类型转换:

  1. 隐式转换
    JavaScript 在某些操作中会自动进行类型转换。

    console.log("5" + 1); // "51" (数字被转换为字符串)
    console.log("5" - 1); // 4 (字符串被转换为数字)
  2. 显式转换
    可以使用内置函数或操作符进行显式类型转换。

    console.log(Number("42")); // 42
    console.log(String(42)); // "42"
    console.log(Boolean(0)); // false

总结

JavaScript 提供了丰富的内置数据类型和数据结构,开发者可以根据需要选择合适的数据类型和结构来处理数据。理解这些类型和结构的特点以及如何进行类型检查和转换,是编写高效、健壮的 JavaScript 代码的基础。

无论是处理简单的原始数据,还是构建复杂的对象结构,JavaScript 都提供了强大的工具。希望本文能帮助你更好地理解 JavaScript 的数据类型和数据结构,为你的开发之旅打下坚实的基础!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入解析XXL-JOB任务调度执行原理

引言 ​ 在分布式系统中,定时任务调度是业务场景中不可或缺的一环。面对海量任务、复杂依赖和高可用性要求,传统单机调度方案逐渐显得力不从心。XXL-JOB作为一款开源的分布式任务调度平台,凭借其轻量级、高扩展性和易用性成为众多企业的选择…

为AI聊天工具添加一个知识系统 之127 详细设计之68 编程 核心技术:Cognitive Protocol Language 之1

本文要点 要点 今天讨论的题目:本项目(为使用AI聊天工具的两天者加挂一个知识系统) 详细程序设计 之“编程的核心技术” 。 source的三个子类(Instrument, Agent, Effector) 分别表示--实际上actually ,…

word转换为pdf后图片失真解决办法、高质量PDF转换方法

1、安装Adobe Acrobat Pro DC 自行安装 2、配置Acrobat PDFMaker (1)点击word选项卡上的Acrobat插件,(2)点击“首选项”按钮,(3)点击“高级配置”按钮(4)点…

Kafka生产者相关

windows中kafka集群部署示例-CSDN博客 先启动集群或者单机也OK 引入依赖 <dependency><groupId>org.apache.kafka</groupId><artifactId>kafka-clients</artifactId><version>3.9.0</version></dependency>关于主题创建 理论…

《Effective Objective-C》阅读笔记(下)

目录 内存管理 理解引用计数 引用计数工作原理 自动释放池 保留环 以ARC简化引用计数 使用ARC时必须遵循的方法命名规则 变量的内存管理语义 ARC如何清理实例变量 在dealloc方法中只释放引用并解除监听 编写“异常安全代码”时留意内存管理问题 以弱引用避免保留环 …

一、对iic类模块分析与使用

bmp280驱动代码 说明&#xff1a; 1、该模块用于获取气压&#xff0c;温度&#xff0c;海拔等数据。 vcc&#xff0c;gnd接电源 sda &#xff0c;scl 接iic通信引脚 2、该模块使用iic通信&#xff0c;通过iic发送请求相关类的寄存器值&#xff0c;芯片获取对应寄存器返回的数据…

辛格迪客户案例 | 祐儿医药科技GMP培训管理(TMS)项目

01 项目背景&#xff1a;顺应行业趋势&#xff0c;弥补管理短板 随着医药科技行业的快速发展&#xff0c;相关法规和标准不断更新&#xff0c;对企业的质量管理和人员培训提出了更高要求。祐儿医药科技有限公司&#xff08;以下简称“祐儿医药”&#xff09;作为一家专注于创新…

汽车低频发射天线介绍

汽车低频PKE天线是基于RFID技术的深度研究及产品开发应用的一种天线&#xff0c;在汽车的智能系统中发挥着重要作用&#xff0c;以下是关于它的详细介绍&#xff1a; 移动管家PKE低频天线结构与原理 结构&#xff1a;产品一般由一个高Q值磁棒天线和一个高压电容组成&#xff…

Java 大视界 -- Java 大数据分布式文件系统的性能调优实战(101)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…

全国普通高等学校名单

全国普通高等学校名单 全国普通高等院校&#xff0c;简称“高校”&#xff0c;是指那些提供高等教育的学校&#xff0c;涵盖了大学、独立学院、高等专科学校以及高等职业学校等多种类型。这些机构通过国家普通高等教育招生考试&#xff0c;主要招收高中毕业生&#xff0c;并为…

Vue.js 学习笔记

文章目录 前言一、Vue.js 基础概念1.1 Vue.js 简介1.2 Vue.js 的特点1.3 Vue.js 基础示例 二、Vue.js 常用指令2.1 双向数据绑定&#xff08;v-model&#xff09;2.2 条件渲染&#xff08;v-if 和 v-show&#xff09;2.3 列表渲染&#xff08;v-for&#xff09;2.4 事件处理&am…

【Python】基础语法三

> 作者&#xff1a;დ旧言~ > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;了解Python的函数、列表和数组。 > 毒鸡汤&#xff1a;有些事情&#xff0c;总是不明白&#xff0c;所以我不会坚持。早安! > 专栏选自&#xff…

传奇3光通版手游行会战攻略:团队协作与战术布局详解

戳一戳&#xff1b;了解更多 在《传奇3光通版》手游中&#xff0c;行会战是玩家们展现团队协作与战术布局的重要舞台。下面&#xff0c;我们就来详细解析一下行会战中的团队协作与战术布局攻略。 一、团队协作 ​职业搭配 在行会战中&#xff0c;合理的职业搭配至关重要。一般…

unity学习56:旧版legacy和新版TMP文本输入框 InputField学习

目录 1 旧版文本输入框 legacy InputField 1.1 新建一个文本输入框 1.2 InputField 的子物体构成 1.3 input field的的component 1.4 input Field的属性 2 过渡 transition 3 控件导航 navigation 4 占位文本 placeholder 5 文本 text 5.1 文本内容&#xff0c;用户…

99分巧克力

99分巧克力 ⭐️难度&#xff1a;中等 &#x1f31f;考点&#xff1a;二分 2017省赛真题 &#x1f4d6; &#x1f4da; import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int n sc.nextInt();i…

Python 基础知识全面总结

Python 是一种广泛应用的编程语言&#xff0c;具有简洁、易读、功能强大等特点。本文将对 Python 的基础知识进行全面梳理&#xff0c;涵盖从入门必备知识到各类模块和编程概念等内容。 一、Python基础语法 &#xff08;一&#xff09;标识符 定义&#xff1a;用于给变量、函…

7.1.1 计算机网络的组成

文章目录 物理组成功能组成工作方式完整导图 物理组成 计算机网络是将分布在不同地域的计算机组织成系统&#xff0c;便于相互之间资源共享、传递信息。 计算机网络的物理组成包括硬件和软件。硬件中包含主机、前端处理器、连接设备、通信线路。软件中包含协议和应用软件。 功…

领域驱动设计:事件溯源架构简介

概述 事件溯源架构通常由3种应用设计模式组成,分别是:事件驱动(Event Driven),事件溯源(Event Source)、CQRS(读写分离)。这三种应用设计模式常见于领域驱动设计(DDD)中,但它们本身是一种应用设计的思想,不仅仅局限于DDD,每一种模式都可以单独拿出来使用。 E…

【AD】3-10 原理图PDF导出

文件—智能PDF 多页原理图导出 导出设置时选择工程&#xff0c;可自行选择导出一页或多页原理图&#xff0c;一般PCB不用导出

半导体制造工艺(二)光刻工艺—掩模版

在上文中我们已经简单概述了光刻工艺的大致流程。接下来将会介绍在光刻工艺中所需用到的必备材料以及设备。例如掩模版、光刻胶、匀胶机、光刻机等等。由于需要保持讲述工艺的完整性以及流畅&#xff0c;每一个都需要涉及&#xff0c;所以每次仅是侧重点不同。此篇主要讲述的是…