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. 当您需要不是字符串的键时使用
相关推荐
光影少年7 分钟前
JS中typeof与instanceof的区别
前端·javascript·掘金·金石计划
康康的幸福生活7 分钟前
webgl2 方法解析: uniformBlockBinding()
前端·javascript·webgl
康康的幸福生活9 分钟前
webgl2 方法解析: uniforms buffer object
前端·javascript·webgl
李永宁9 分钟前
开发环境配置安全的 HTTPS 协议
前端·javascript·https
小高00711 分钟前
💥前端开发 2025 生存指南:调试不靠 console.log 靠什么?
前端·javascript·面试
康康的幸福生活14 分钟前
webgl2 方法解析: bindBufferBase()
前端·javascript·webgl
小高00715 分钟前
面试官:说说 Webpack 和 Vite 的区别
前端·javascript·面试
阿虎儿42 分钟前
Modern Node.js Patterns for 2025(2025 年现代 Node.js 模式)
javascript·node.js
江城开朗的豌豆1 小时前
告别Class组件!用useEffect玩转React生命周期
前端·javascript·react.js
江城开朗的豌豆1 小时前
React状态管理:从Context到Redux,我的选型心得
前端·javascript·react.js