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. 当您需要不是字符串的键时使用
相关推荐
Можно3 小时前
深入理解 ES6 Proxy:与 Object.defineProperty 的全面对比
前端·javascript·vue.js
天天向上10245 小时前
vue el-table实现拖拽排序
前端·javascript·vue.js
西西学代码5 小时前
Flutter---回调函数
开发语言·javascript·flutter
卷帘依旧6 小时前
JavaScript 闭包经典问题:为什么输出 10 次 i=10
javascript
柳杉6 小时前
Three.js × Blender:从建模到 Web 3D 的完整工作流深度解析
前端·javascript·数据可视化
用户806138166597 小时前
发布为一个 npm 包
前端·javascript
TT_哲哲8 小时前
小程序双模式(文件 / 照片)上传组件封装与解析
前端·javascript
从文处安8 小时前
「九九八十一难」从回调地狱到异步秩序:深入理解 JavaScript Promise
前端·javascript
进击的尘埃8 小时前
Node.js 子进程管理:child_process 模块的正确打开方式
javascript
angerdream8 小时前
最新版vue3+TypeScript开发入门到实战教程之Pinia详解
前端·javascript·vue.js