null被指定为尾部递归函数中的对象



我有一个尾部递归函数,其目的是在任何数量的嵌套objects中找到任何number,并在其上运行toFixed()

函数formatData((的工作原理是循环object,测试当前迭代的值类型,对所述迭代执行函数(toFixed(((并将其保存在一个新对象中,或者什么都不做,只按原样保存值。最终结果将是一个相同的对象,但任何长的小数位数都会修剪到两个小数位数。

在测试过程中,我发现如果在任何级别的object中有一个null值,它首先被保存为null,但后来变成了object。我知道在JS中,null被认为是object类型,typeof关键字将显示这一点。

以下是问题的代码笔:https://codepen.io/Danny_Wobble/pen/YzqMzxw请注意,第三个控制台条目显示了正确分配/保存为null的值。稍后,如所述,它最终成为object

功能:

function formatData(data) {
const formattedData = {}
for (const key in data) {
if (data[key] === null) formattedData[key] = null
// if (data[key] === null) formattedData[key] = 'null' // have tried saving as diff val, didn't work
if (data[key] === false) formattedData[key] = false
if (typeof data[key] === 'number') formattedData[key] = data[key].toFixed(2)
if (typeof data[key] === 'object') formattedData[key] = formatData(data[key]) // tail recursion
}
return formattedData
}

给定:

const data = {
status: false,
survey: {
2018: 3.4288,
2019: 3.47701,
2020: null,
},
benchmarks: {
company: 3.455,
industry: 3.5,
portfolio: 3.4,
},
}
const formattedData = formatData(data)

预期(格式化数据(:

{
"status": false,
"survey": {
"2018": "3.43",
"2019": "3.48",
"2020": null,
},
"benchmarks": {
"company": "3.50",
"industry": "3.50",
"portfolio": "3.40",
},
}

实际结果(格式化数据(:

{
"status": false,
"survey": {
"2018": "3.43",
"2019": "3.48",
"2020": {} // this should be `null`
},
"benchmarks": {
"company": "3.50",
"industry": "3.50",
"portfolio": "3.40"
}
}

您需要从对象检查中排除null值。

if (data[key] && typeof data[key] === 'object')
//  ^^^^^^^^^^^^

您可以更改逻辑,只检查不同处理的值,如数字和对象以及continue,或者只将给定值分配给新对象。

function formatData(data) {
const formattedData = {}
for (const key in data) {
if (typeof data[key] === 'number') {
formattedData[key] = data[key].toFixed(2)
continue;
}
if (data[key] && typeof data[key] === 'object') {
formattedData[key] = formatData(data[key]);
continue;
}
formattedData[key] = data[key];
}
return formattedData;
}
const
data = {
status: false,
survey: {
2018: 3.4288,
2019: 3.47701,
2020: null
},
benchmarks: {
company: 3.455,
industry: 3.5,
portfolio: 3.4
}
},
formattedData = formatData(data);
console.log(formattedData);

相关内容

  • 没有找到相关文章

最新更新