如何保持顺序替换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对象数组中的键和值?的详细内容,更多请关注其它相关文章!