如何保持顺序替换JavaScript对象数组中的键和值?

如何保持顺序替换javascript对象数组中的键和值?

如何在保持顺序的情况下替换javascript对象数组中的键和值?

问题提出:

当您尝试替换具有数字键和字符串键的javascript对象数组中的键和值时,您可能会遇到数据顺序改变的问题。例如,您可能希望将对象中的a键替换为d键,但这样做会导致数据顺序发生变化。

解决方法:

解决此问题的关键在于理解javascript对象键的顺序。javascript对象中的键按照数字键的升序和非数字键的插入顺序进行排序。

可以通过使用避免使用数字键来保持数据顺序。可以通过以下方式实现:

function replaceobjkeywithorder<t extends object>(
  obj: t,
  kold: keyof t & string,
  knew: string
) {
  const entries = object.entries(obj),
    entry = entries.find(([k]) => k === kold)
  entry && (entry[0] = knew)
  return object.fromentries(entries)
}

const tabledata = [
    {
      a: "12a",
      b: "12b",
    },
    {
      a: "13a",
      b: "13b",
    },
  ],
  newtabledata = tabledata.map((v) => replaceobjkeywithorder(v, "a", "d"))

console.log("before:", tabledata)
console.log("after:", newtabledata)</t>

输出:

before: [
  { A: "12A", B: "12B" },
  { A: "13A", B: "13B" }
]
after: [
  { D: "12A", B: "12B" },
  { D: "13A", B: "13B" }
]

此方法保持了数据顺序不变,因为新键d不是数字键,因此它不会影响排序。

以上就是如何保持顺序替换JavaScript对象数组中的键和值?的详细内容,更多请关注其它相关文章!