0

0

如何将对象中键名含相同数字后缀的属性配对合并为数组对象

花韻仙語

花韻仙語

发布时间:2026-01-20 14:51:33

|

401人浏览过

|

来源于php中文网

原创

如何将对象中键名含相同数字后缀的属性配对合并为数组对象

本文介绍一种高效、可扩展的方法,将具有相同数字后缀的键值对(如 `lote0` 与 `loteqnt0`)自动分组并组合成结构化对象数组,避免硬编码过滤逻辑,支持任意前缀和多组匹配。

在实际开发中,我们常遇到这类“带编号键名”的扁平对象,例如表单数据、配置项或 API 响应:

const vls = {
  "lote0": "jg",
  "lote1": "h",
  "lote2": "fm",
  "loteQnt0": "jgvalue",
  "loteQnt1": "hvalue",
  "loteQnt2": "fmvalue"
};

目标是按数字后缀(0, 1, 2…)将匹配的键聚合,生成如下结构的数组:

[
  { name: "jg", value: "jgvalue" },
  { name: "h",  value: "hvalue"  },
  { name: "fm", value: "fmvalue" }
]

推荐实现(健壮、可复用、无硬编码):
我们不预先假设前缀(如 "lote" 或 "loteQnt"),而是通过正则提取所有键的「数字后缀」,再按该数字分组键名,最后映射为统一字段名的对象。

function groupByNumberSuffix(obj, keyMap = {}) {
  // 步骤 1:提取所有键的数字后缀,并归类
  const groups = new Map(); // Map

  Object.entries(obj).forEach(([key, value]) => {
    const match = key.match(/(\D+)(\d+)$/); // 匹配末尾数字,如 'lote0' → ['lote0','lote','0']
    if (!match) return;

    const [, prefix, numStr] = match;
    const num = Number(numStr);

    if (!groups.has(num)) {
      groups.set(num, {});
    }
    groups.get(num)[prefix] = value;
  });

  // 步骤 2:按 keyMap 映射字段名(默认:prefix → 小驼峰首字母)
  const result = [];
  for (const [num, groupObj] of groups.entries()) {
    const mapped = {};
    for (const [prefix, val] of Object.entries(groupObj)) {
      const targetKey = keyMap[prefix] || 
                        prefix.replace(/^[a-z]/, c => c.toUpperCase()); // 如 'lote' → 'Lote'
      mapped[targetKey] = val;
    }
    result.push(mapped);
  }

  // 步骤 3:按数字升序返回(确保 0,1,2…顺序)
  return result.sort((a, b) => {
    const numA = Object.keys(a).find(k => /\d+/.test(k)) || '0';
    const numB = Object.keys(b).find(k => /\d+/.test(k)) || '0';
    return parseInt(numA) - parseInt(numB);
  });
}

// 使用示例:
const vls = {
  "lote0": "jg", "lote1": "h", "lote2": "fm",
  "loteQnt0": "jgvalue", "loteQnt1": "hvalue", "loteQnt2": "fmvalue"
};

const result = groupByNumberSuffix(vls, {
  lote: 'name',
  loteQnt: 'value'
});

console.log(result);
// → [
//     { name: "jg", value: "jgvalue" },
//     { name: "h",  value: "hvalue"  },
//     { name: "fm", value: "fmvalue" }
//   ]

? 关键优势说明:

Simplified
Simplified

AI写作、平面设计、编辑视频和发布内容。专为团队打造。

下载
  • 动态识别后缀:无需手动拆分 lote* 和 loteQnt*,正则 /(\D+)(\d+)$/ 自动捕获前缀与数字;
  • 灵活字段映射:通过 keyMap 参数声明 lote → name、loteQnt → value,语义清晰且可扩展;
  • 健壮容错:跳过无数字后缀的键(如 "meta"),不中断流程;
  • 有序输出:结果按数字升序排列,符合直觉;
  • 零依赖:纯 JavaScript,兼容 ES2015+。

⚠️ 注意事项:

  • 键名必须以「非数字字符 + 数字」结尾(如 item123 ✅,123item ❌,item_123 ❌);若需支持下划线等分隔符,可调整正则为 /(\D+?)_(\d+)$/ 或 /(\D+?)(\d+)$/;
  • 若同一数字对应多个同前缀键(如两个 lote0),后者会覆盖前者——建议确保原始数据键唯一;
  • 如需支持嵌套结构或更复杂匹配逻辑,可进一步封装为 groupByPattern(patterns) 函数。

总结:该方案将「按数字归组」这一通用需求抽象为可配置函数,兼顾简洁性与工程健壮性,适用于表单批量解析、动态表格渲染、配置合并等多种场景。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

556

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

374

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

733

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

477

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

414

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

1011

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

658

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

553

2023.09.20

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

13

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.9万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号