当前位置: 首页 > news >正文

从0开始学习JavaScript--JavaScript数据类型与数据结构

JavaScript作为一门动态、弱类型的脚本语言,拥有丰富的数据类型和数据结构,这些构建了语言的基础,为开发者提供了灵活性和表达力。本文将深入探讨JavaScript中的各种数据类型,包括基本数据类型和复杂数据类型,并介绍常用的数据结构,以丰富的示例代码帮助读者更好地理解和应用这些概念。

基本数据类型

JavaScript有七种基本数据类型,分别是:

  • Number(数字)
  • String(字符串)
  • Boolean(布尔)
  • Null(空)
  • Undefined(未定义)
  • Symbol(符号,ES6新增)
  • BigInt(大整数,ES2020新增)
// 示例:基本数据类型
let num = 42; // Number
let str = 'Hello, World!'; // String
let isTrue = true; // Boolean
let empty = null; // Null
let notDefined = undefined; // Undefined
let sym = Symbol('unique'); // Symbol
let bigInt = 9007199254740991n; // BigInt

引用数据类型

引用数据类型包括:

  • Object(对象)
  • Array(数组)
  • Function(函数)
  • Date(日期)
  • RegExp(正则表达式)
  • Map(映射)
  • Set(集合)
// 示例:引用数据类型
let obj = { key: 'value' }; // Object
let arr = [1, 2, 3]; // Array
let func = function() { /* 函数体 */ }; // Function
let today = new Date(); // Date
let regex = /pattern/; // RegExplet map = new Map();
map.set('name', 'John'); // Maplet set = new Set();
set.add(1).add(2).add(3); // Set

类型转换

JavaScript是一门弱类型语言,它会自动进行类型转换。了解类型转换有助于我们更好地理解代码的执行过程。

// 示例:类型转换
let numAsString = '42';
let convertedNum = Number(numAsString);
console.log(convertedNum); // 输出:42let boolAsString = 'true';
let convertedBool = Boolean(boolAsString);
console.log(convertedBool); // 输出:true

数据结构

1 数组(Array)

数组是一种有序的集合,可以包含任意类型的数据。

// 示例:数组
let fruits = ['apple', 'orange', 'banana'];
console.log(fruits[0]); // 输出:apple
console.log(fruits.length); // 输出:3

2 对象(Object)

对象是一种无序的集合,由键值对组成。

// 示例:对象
let person = {name: 'John',age: 30,city: 'New York'
};
console.log(person.name); // 输出:John

3 Map和Set

Map是一种键值对的集合,而Set是一种值的集合,它们提供了更灵活的数据组织方式。

// 示例:Map和Set
let userMap = new Map();
userMap.set('name', 'Alice').set('age', 25);let uniqueNumbers = new Set([1, 2, 3, 4, 5, 5, 5]);

JSON

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,常用于前后端数据传输。

// 示例:JSON
let jsonData = '{"name": "Bob", "age": 28}';
let parsedData = JSON.parse(jsonData);
console.log(parsedData.name); // 输出:Boblet dataToBeSent = { status: 'success', code: 200 };
let jsonString = JSON.stringify(dataToBeSent);

迭代与遍历

JavaScript提供了多种迭代和遍历数据结构的方式,如for...of循环、forEach方法等。

// 示例:迭代与遍历
let numbers = [1, 2, 3, 4, 5];
for (let num of numbers) {console.log(num);
}numbers.forEach(num => {console.log(num);
});

数据类型与数据结构的选择

在实际开发中,选择合适的数据类型和数据结构至关重要。例如,使用数组来存储有序的数据集合,使用对象或Map来存储键值对。

// 示例:数据类型与数据结构的选择
let student1 = { name: 'Alice', age: 20, grade: 'A' };
let student2 = { name: 'Bob', age: 22, grade: 'B' };
let studentsArray = [student1, student2];let studentsMap = new Map();
studentsMap.set('Alice', { age: 20, grade: 'A' });
studentsMap.set('Bob', { age: 22, grade: 'B' });

常见问题与解决方案

在处理JavaScript数据类型和数据结构时,常常会遇到一些常见的问题,例如如何遍历嵌套对象、如何判断数据类型等。以下是一些常见问题的解决方案。

1 遍历嵌套对象

遍历嵌套对象需要使用递归或其他迭代方法。

// 示例:遍历嵌套对象
function recursiveIteration(obj) {for (let key in obj) {if (typeof obj[key] === 'object' && obj[key] !== null) {recursiveIteration(obj[key]);} else {console.log(obj[key]);}}
}let nestedObject = {key1: 'value1',key2: {key3: 'value3',key4: {key5: 'value5'}}
};recursiveIteration(nestedObject);

2 判断数据类型

判断数据类型可以使用typeof运算符,但对于对象和数组,更准确的方式是使用Array.isArrayObject.prototype.toString方法。

// 示例:判断数据类型
let data = [1, 2, 3];console.log(typeof data); // 输出:object
console.log(Array.isArray(data)); // 输出:true
console.log(Object.prototype.toString.call(data)); // 输出:[object Array]

实战示例

结合实际场景,可以使用数据类型和数据结构来解决具体问题。比如,在一个学生信息管理系统中,可以使用对象存储学生信息,数组存储所有学生,通过遍历和查询实现各种功能。

// 示例:学生信息管理系统
let students = [{ name: 'Alice', age: 20, grade: 'A' },{ name: 'Bob', age: 22, grade: 'B' },// 更多学生...
];function addStudent(student) {students.push(student);
}function findStudentByName(name) {return students.find(student => student.name === name);
}// 其他功能函数...// 添加新学生
addStudent({ name: 'Charlie', age: 21, grade: 'A' });// 查找学生信息
let foundStudent = findStudentByName('Bob');
console.log(foundStudent); // 输出:{ name: 'Bob', age: 22, grade: 'B' }

总结

深入理解JavaScript的数据类型与数据结构对于编写高效、清晰的代码至关重要。通过对基本数据类型、引用数据类型、常见数据结构以及类型转换的深入学习,能够更好地应用这些知识解决实际问题。

随着JavaScript语言的发展,可以期待更多新的数据类型和数据结构的出现,以及更多方便的数据操作方法,进一步提高开发效率。希望本文能够为大家提供对JavaScript数据类型与数据结构的深入了解,为日后的编程实践提供有力的支持。

相关文章:

从0开始学习JavaScript--JavaScript数据类型与数据结构

JavaScript作为一门动态、弱类型的脚本语言,拥有丰富的数据类型和数据结构,这些构建了语言的基础,为开发者提供了灵活性和表达力。本文将深入探讨JavaScript中的各种数据类型,包括基本数据类型和复杂数据类型,并介绍常…...

数据结构与算法编程题20

统计二叉树的叶结点个数。 #define _CRT_SECURE_NO_WARNINGS#include <iostream> using namespace std;typedef char ElemType; #define ERROR 0 #define OK 1 typedef struct BiNode {ElemType data;BiNode* lchild, * rchild; }BiNode,*BiTree;bool Create_tree(BiTre…...

FreeRTOS源码阅读笔记5--mutex

互斥量是一种特殊的二值信号量&#xff0c;拥有优先级继承的机制&#xff0c;所以适合用在临界资源互斥访问。 5.1创建互斥量xSemaphoreCreateMutex() 5.1.1函数原型 5.1.2函数框架 5.2创建递归互斥量xSemaphoreCreateRecursiveMutex() 5.2.1函数原型 5.2.2函数框架 xSemaph…...

STM32_7(ADC)

一、ADC ADC&#xff08;Analog-Digital Converter&#xff09;模拟-数字转换器ADC可以将引脚上连续变化的模拟电压转换为内存中存储的数字变量&#xff0c;建立模拟电路到数字电路的桥梁12位逐次逼近型ADC&#xff0c;1us转换时间输入电压范围&#xff1a;0~3.3V&#xff0c;…...

Flink实战(11)-Exactly-Once语义之两阶段提交

0 大纲 [Apache Flink]2017年12月发布的1.4.0版本开始&#xff0c;为流计算引入里程碑特性&#xff1a;TwoPhaseCommitSinkFunction。它提取了两阶段提交协议的通用逻辑&#xff0c;使得通过Flink来构建端到端的Exactly-Once程序成为可能。同时支持&#xff1a; 数据源&#…...

日志技术logback

一&#xff0c;日志概括 二&#xff0c;日志技术的特点 三&#xff0c;日志技术的体系 三&#xff0c;入门 四&#xff0c;案例 package XinZheng;import org.slf4j.Logger; import org.slf4j.LoggerFactory;public class Main58 {//1,创建一个Logger日志对象public static fi…...

linux(1)之build构建系统基础(一)

Linux(1)之buildroot构建系统(一) Author&#xff1a;Onceday Date&#xff1a;2023年11月12日 漫漫长路&#xff0c;才刚刚开始… 参考文档&#xff1a; The Yocto ProjectBuildroot - Making Embedded Linux Easy 文章目录 Linux(1)之buildroot构建系统(一)1. 概述1.1 如…...

25 Linux I2C 驱动

一、I2C简介 I2C老朋友了&#xff0c;在单片机里面也学过&#xff0c;现在再复习一下。I2C使用两条线在主控制器和从机之间进行数据通信。一条是 SCL(串行时钟线)&#xff0c;另外一条是 SDA(串行数据线)&#xff0c;这两条数据线需要接上拉电阻&#xff0c;总线空闲的时候 SCL…...

API 设计:使用 Node.js 和 Express.js 的综合教程

API&#xff08;应用程序编程接口&#xff09;设计涉及创建一个高效而强大的接口&#xff0c;允许不同的软件应用程序相互交互。 说明 本教程将指导您使用 Node.js 和 Express.js 作为核心技术来规划、设计和构建 API。但是&#xff0c;这些原则可以应用于任何语言或框架。我们…...

vite和webpack的区别和练习

Vite和Webpack都是现代化的前端构建工具&#xff0c;但它们之间存在一些区别&#xff1a; 构建性能&#xff1a;Vite使用ES Modules提高了构建性能&#xff0c;可以在构建时只构建需要的部分&#xff0c;而Webpack则需要在构建时处理整个应用程序。 开发体验&#xff1a;Vite具…...

Python与设计模式--装饰器模式

6-Python与设计模式–装饰器模式 一、快餐点餐系统 又提到了那个快餐点餐系统&#xff0c;不过今天我们只以其中的一个类作为主角&#xff1a;饮料类。 首先&#xff0c;回忆下饮料类&#xff1a; class Beverage():name ""price 0.0type "BEVERAGE"…...

flutter之graphic图表自定义tooltip

renderer graphic中tooltip的TooltipGuide类提供了renderer方法&#xff0c;接收三个参数Size类型&#xff0c;Offset类型&#xff0c;Map<int, Tuple>类型。可查到的文档是真的少&#xff0c;所以只能在源码中扒拉例子&#xff0c;做符合需求的修改。 官方github示例 …...

逆向扒cocosjs安卓包教程-破解加密的js源码

本文只适用于cocosjs引擎打包的游戏apk,针对此类apk进行源码级别的逆向破解,可直接逐个破解工程内的源码部分,让游戏逻辑大白于你的面前,你可以针对js源码进行二次开发。按照我的教程破解过程中遇到什么问题,欢迎留言。 目录 准备apk包 查找加密key 解密jsc文件 方案1…...

Kafka(一)

一&#xff1a;简介 解决高吞吐量项目的需求 是一款为大数据而生的消息中间件&#xff0c;具有百亿级tps的吞吐量&#xff0c;在数据采集、传输、存储的过程中发挥着作用 二&#xff1a;为什么要使用消息队列 一个普通访问量的接口和一个大并发的接口&#xff0c;它们背后的…...

【Amazon】安装卸载AWS CLI操作流程(Windows 、Linux系统)

AWS 命令行界面&#xff08;AWS CLI&#xff09;是用于管理 AWS 产品的统一工具。只需要下载和配置一个工具&#xff0c;您就可以使用命令行控制多个 AWS 产品并利用脚本来自动执行这些服务。 AWS CLI v2 提供了多项新功能&#xff0c;包括改进的安装程序、新的配置选项&#…...

Django同时连接多种数据库

我的使用场景需要同时连接达梦数据库和MYSQL数据库&#xff0c;有的功能需要查询达梦&#xff0c;有的功能则需要查询MYSQL。 第一步&#xff1a;在 Django 的 settings.py 文件中&#xff0c;配置多个数据库连接。你可以在 DATABASES 字典中添加多个数据库配置。每个数据库配置…...

【链表之练习题】

文章目录 翻转链表找到链表的中间节点返回倒数第k个节点合并两个有序链表判断链表是否回文注意 翻转链表 //反转链表//实质上是把每一个节点头插法,原本第一个节点变成最后一个节点public ListNode reverseList(){//链表为空if (head null){return null;}//链表只有一个节点if…...

情感对话机器人的任务体系

人类在处理对话中的情感时&#xff0c;需要先根据对话场景中的蛛丝马迹判断出对方的情感&#xff0c;继而根据对话的主题等信息思考自身用什么情感进行回复&#xff0c;最后结合推理出的情感形成恰当的回复。受人类处理情感对话的启发&#xff0c;情感对话机器人需要完成以下几…...

【笔记 Pytorch 08】深度学习模板 (未完)

文章目录 一、声明二、工程结构三、文件内容main.pymodel.pydataset.pyutils.py 四、问题汇总 一、声明 非常感谢这些资料的作者&#xff1a; 【参考1】、【PyTorch速成教程 (by Sung Kim)】 二、工程结构 ├── main.py&#xff1a;实现训练 (train) 、验证(validation)和…...

【如何学习Python自动化测试】—— Cookie 处理

前提 网络通信是当今社会最为普及和繁荣的技术之一&#xff0c;其承载了人们生活中瞬息万变的信息传递和交流。而作为网络通信的核心要素&#xff0c;网络协议、socket、cookie和session则是网络通信的灵魂。 一、网络协议 网络协议是计算机和网络设备之间相互通信的规则和标准…...

Phi-mini-MoE-instruct效果实测:长文本摘要+关键信息抽取双任务

Phi-mini-MoE-instruct效果实测&#xff1a;长文本摘要关键信息抽取双任务 1. 模型概览 Phi-mini-MoE-instruct是一款轻量级混合专家&#xff08;MoE&#xff09;指令型小语言模型&#xff0c;在多项基准测试中展现出卓越性能&#xff1a; 代码能力&#xff1a;在RepoQA、Hu…...

Face3D.ai Pro使用技巧:掌握这几点,让你的3D重建效果提升一个档次

Face3D.ai Pro使用技巧&#xff1a;掌握这几点&#xff0c;让你的3D重建效果提升一个档次 1. 为什么你的3D重建效果不够理想&#xff1f; 1.1 输入照片的质量决定重建上限 Face3D.ai Pro虽然强大&#xff0c;但"垃圾进、垃圾出"的原则依然适用。经过上百次测试&am…...

从连续到数字:深入解读Matlab离散化函数c2d的6种方法及其在滤波器与控制器设计中的选用

从连续到数字&#xff1a;Matlab离散化函数c2d的6种方法及其在工程实践中的精准选用 在数字信号处理和控制系统的设计中&#xff0c;连续时间系统的离散化是一个无法绕开的关键环节。就像摄影师需要将现实世界的连续光影转化为数码相机中的像素一样&#xff0c;工程师也需要将连…...

避开Verilog新手村陷阱:Hdlbits刷题时最容易犯的5个语法错误及调试技巧

避开Verilog新手村陷阱&#xff1a;Hdlbits刷题时最容易犯的5个语法错误及调试技巧 深夜的显示器前&#xff0c;你盯着Hdlbits的报错信息已经半小时——这已经是今晚第七次编译失败。Verilog语法看似简单&#xff0c;但那些隐藏在细节中的陷阱总能让初学者抓狂。本文将解剖五个…...

LSLib终极指南:轻松制作《神界原罪》与《博德之门3》游戏MOD的完整教程

LSLib终极指南&#xff1a;轻松制作《神界原罪》与《博德之门3》游戏MOD的完整教程 【免费下载链接】lslib Tools for manipulating Divinity Original Sin and Baldurs Gate 3 files 项目地址: https://gitcode.com/gh_mirrors/ls/lslib 想要为《神界原罪》系列或《博德…...

Visual C++ Redistributable AIO:一站式解决Windows运行库问题的终极方案

Visual C Redistributable AIO&#xff1a;一站式解决Windows运行库问题的终极方案 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist Visual C Redistributable AI…...

深入TMS320F28335 GPIO:从寄存器手册到代码,手把手教你玩转LED控制

TMS320F28335 GPIO深度解析&#xff1a;从寄存器到LED控制的硬核实践 第一次接触TI的C2000系列DSP时&#xff0c;我被其强大的实时控制能力和丰富的外设所吸引。但真正开始编程时&#xff0c;却发现要驾驭这颗芯片&#xff0c;必须深入理解其底层硬件机制。本文将带你从寄存器层…...

Webcamoid:智能高效的跨平台网络摄像头管理解决方案

Webcamoid&#xff1a;智能高效的跨平台网络摄像头管理解决方案 【免费下载链接】webcamoid Webcamoid is a full featured and multiplatform camera suite. 项目地址: https://gitcode.com/gh_mirrors/we/webcamoid 在数字化时代&#xff0c;网络摄像头已成为视频会议…...

从源码到CFG:深入解析编译中间表示的转换链路

1. 源码到AST&#xff1a;从文本到树形结构的蜕变 当你用Java或Python写下一行代码时&#xff0c;计算机看到的其实只是一堆字符。就像读一本外文书&#xff0c;首先要把它翻译成自己能理解的结构。这就是编译器的第一个任务——把源码变成AST&#xff08;抽象语法树&#xff0…...

终极指南:如何用genshin-fps-unlock免费解锁原神帧率限制,让你的游戏体验流畅翻倍

终极指南&#xff1a;如何用genshin-fps-unlock免费解锁原神帧率限制&#xff0c;让你的游戏体验流畅翻倍 【免费下载链接】genshin-fps-unlock unlocks the 60 fps cap 项目地址: https://gitcode.com/gh_mirrors/ge/genshin-fps-unlock 还在为《原神》60FPS的帧率限制…...