JavaScript总结_使用哪种数据结构?

数据解构概述

数据从哪里来?

  1. 来自程序本身:直接在源代码中写入的数据(例如状态消息);
  2. 来自UI:用户输入的数据或DOM中写入的数据(例如todo应用程序中的任务);
  3. 从外部来源:例如从Web API获取的数据(例如配方对象);【注:Web API应用编程接口,例如可以像下面的一个JOSN文件】

● 当我们知道数据从哪来的时候,我们下一步应该收集数据;

● 当我们收集数据的时候,我们就要选择数据结构,例如数据是简单的一个清单,我们可以使用数据或集合;如果数据存在键/值对,我们就会选择对象或者Map这种数据结构;(注:键允许我们去描述值)

数组 VS. 集合 And 对象 VS. MAPS

数组 VS. 集合

数组
1. 当你需要有序的值列表时候使用(可能包含重复项)
2. 当您需要操作数据时使用
集合

  1. 当您需要使用独特的价值观工作时使用
  2. 在高性能真的非常重要时使用
  3. 用于从数组中删除重复值

对象 VS. MAPS

对象

  1. 更多的"传统"键/值存储("滥用"对象);
  2. 更加容编写和访问值;
  3. 当你需要包含函数时(方法)
  4. 在使用JOSN时使用(可以转换为映射)

MAPS

  1. 更好的性能
  2. 键可以有任何数据类型
  3. 易于迭代
  4. 易于计算MAPS大小
  5. 当您只需要将键映射到值时使用
  6. 当您需要不是字符串的键时使用
相关推荐
Lee川14 小时前
深度解构JavaScript:作用域链与闭包的内存全景图
javascript·面试
_Eleven15 小时前
Pinia vs Vuex 深度解析与完整实战指南
前端·javascript·vue.js
技术狂小子15 小时前
# 一个 Binder 通信中的多线程同步问题
javascript·vue.js
进击的尘埃15 小时前
Service Worker + stale-while-revalidate:让页面"假装"秒开的那些事
javascript
秋水无痕16 小时前
从零搭建个人博客系统:Spring Boot 多模块实践详解
前端·javascript·后端
进击的尘埃16 小时前
基于 Claude Streaming API 的多轮对话组件设计:状态机与流式渲染那些事
javascript
juejin_cn16 小时前
[转][译] 从零开始构建 OpenClaw — 第六部分(持久化记忆)
javascript
juejin_cn17 小时前
[转][译] 从零开始构建 OpenClaw — 第七部分(子智能体系统)
javascript
an3174218 小时前
解决 VSCode 中 ESLint 格式化不生效问题:新手也能看懂的配置指南
前端·javascript·vue.js
Lee川20 小时前
🚀《JavaScript 灵魂深处:从 V8 引擎的“双轨并行”看执行上下文的演进之路》
javascript·面试