数据对比中的”平等性原则“

2026/3/14 22:01 星期六

我在做数据接入的时遇到了一个情况: 有两个相同的对象:secne, street,他们的形式相同,都是[{...}, {...}],内容也相同,都是{"2025-11-01 10": 10}的形式。

我需要转换成这种形式:

css 复制代码
[  { "x": "1/01", "y": 5, "s": "道路数量" },  { "x": "1/01", "y": 8, "s": "景观数量" },  { "x": "1/01", "y": 13, "s": "总数" },  ...]

我的思路是

  1. 准备一个数组let result = []
  2. 找到大的一方
  3. 遍历大的一方,然后根据大的一方取去取小的一方,取得到就拿,取不到则用0兜底
  4. 计算他们的和
  5. 用push填入result
ini 复制代码
// ❌ 这样做:分出了主次
const secneSize = Object.keys(secne).length;
const streetSize = Object.keys(street).length;
const largeOne = secneSize >= streetSize ? secne : street;

if (secneSize >= streetSize) {
  // 用 secne 的 key 遍历,去 street 里取值
} else {
  // 用 street 的 key 遍历,去 secne 里取值
}

但问题就出在这里: 这样做会明确的区分主次,导致的结果是我需要把这个判断逻辑写两次,难以维护。尽管可以抽成函数的形式来表示,但依旧会把逻辑写的很复杂。

但也可以换个思路: 不区分二者的大小,而是先找到key比较多的对象,遍历它,然后同时去取两个对象的值,同时处理

ini 复制代码
// ✅ 这样做:平等看待
const secneKeys = Object.keys(secne);
const streetKeys = Object.keys(street);
const primaryKeys = 
  secneKeys.length >= streetKeys.length ? secneKeys : streetKeys;

primaryKeys.forEach((key) => {
  const secneVal = secne[key] || 0;    // 同时从两边取
  const streetVal = street[key] || 0;
  // 统一处理
});

这样做有几个好处

  • 不再需要维护if分支
  • 可读性强,不需要在脑子里存储谁遍历谁,从哪里取值,而是找出最大的,同时遍历,取值,结束。非常好读
  • 统一容错,所有的默认值都是0

因此,我认为当遇到整合多方数据时要避免让某一个成为"主体",而是应该让每一个都保持平等的地位------选出一个合理的遍历源(比如 keys 更多的那个),然后从所有数据源里同时取值、同时处理。

ini 复制代码
// 类似的场景:对比两个数组
// ❌ 区分主次
const larger = arr1.length >= arr2.length ? arr1 : arr2;
const smaller = arr1.length >= arr2.length ? arr2 : arr1;

larger.forEach((item, idx) => {
  const val1 = larger[idx];
  const val2 = smaller[idx] || null;
});

// ✅ 平等处理
const maxLen = Math.max(arr1.length, arr2.length);
for (let i = 0; i < maxLen; i++) {
  const val1 = arr1[i] || null;
  const val2 = arr2[i] || null;
  // 同时处理
}
相关推荐
摸鱼仙人~20 分钟前
Vue中markdown-it基础使用教程
前端·javascript·vue.js
落魄江湖行28 分钟前
入门篇二:Nuxt 4路由自动生成:告别手动配置路由的日子
前端·vue.js·typescript·nuxt4
CQU_JIAKE1 小时前
4.4【Q】
java·前端·javascript
小陈工1 小时前
Python Web开发入门(十二):使用Flask-RESTful构建API——让后端开发更优雅
开发语言·前端·python·安全·oracle·flask·restful
木斯佳1 小时前
前端八股文面经大全:字节前端一面(2026-04-03)·面经深度解析
前端·面试题·面经
xiaotao1312 小时前
第八章:实战项目案例
前端·vue.js·vite·前端打包
We་ct2 小时前
JS手撕:性能优化、渲染技巧与定时器实现
开发语言·前端·javascript·面试·性能优化·定时器·性能
taWSw5OjU2 小时前
vue对接海康摄像头-H5player
开发语言·前端·javascript
huwuhang2 小时前
跨平台电子书阅读器 | Readest最新版 安卓版+PC版全平台
android·前端·javascript
C澒2 小时前
AI 生码:RAG 检索优化实现可评估、可回溯工程化
前端·ai编程