gpt4 book ai didi

javascript - 使用键或循环在 Javascript 中访问对象属性的区别

转载 作者:行者123 更新时间:2023-11-30 13:55:28 27 4
gpt4 key购买 nike

我有一个线性(或单一维度)对象,在单个记录中有超过 1000 个属性。我要遍历超过10000条记录。有时所需的属性可能不包含在单个记录中的对象中。我想知道通过循环对象的所有属性或通过引用直接检查对象中的键是否可用来遍历它们的更好策略是什么。请查看以下示例以更好地理解这一点。

让我们考虑一个示例场景:

var a = {
"x": 1,
"y": 2,
"z": 3,
"t": 4
}; //linear object
var flagA = false;
var b = {
"x": 10,
"y": 11,
"z": 12
}; //linear object
var flagB = false;


//now I have to check the value of "t" in both objects.

//----------------------------------By use of looping-------------------------------//
for (var i in a) {
if (i == "t") {
flagA = true;
break;
}
}

for (var i in b) {
if (i == "t") {
flagB = true;
break;
}
}

//for object a
if (flagA) console.log("value found in object a for t:", a.t);
else console.log("value not found for t in object a");

//for object b
if (flagB) console.log("value found in object b for t:", a.t);
else console.log("value not found for t in object b");


//--------------------------------------------------------------------------------------//
console.log("\nANOTHER METHOD\n");
//-----------------------------------By use of Key-------------------------------------//

//for object a
if (a["t"]) console.log("value found in object a for t:", a["t"]);
else console.log("value not found for t in object a");

//for object b
if (b["t"]) console.log("value found in object b for t:", b["t"]);
else console.log("value not found for t in object b");
//--------------------------------------------------------------------------------------//

我应该使用哪一种方法,为什么?

最佳答案

循环在这里绝对是不必要的,特别是因为你正在处理对象的大量属性 - 检查属性是否存在是一个 O(1) 操作,而循环遍历所有属性搜索特定匹配项是一个 O(N) 操作。所以你的第二种方法肯定更好 - 它需要更少的时间,并且代码更易读。

也就是说:

if (a["t"]) console.log("value found in object a for t:", a["t"]);

这不是一个好的测试,因为如果该属性存在但值为 false,这将失败。

const a = {
t: 0
};

if (a["t"]) {
console.log("value found in object a for t:", a["t"]);
} else {
console.log('not found!');
}

改用hasOwnProperty:

if (a.hasOwnProperty('t'))

var a = {
"x": 1,
"y": 2,
"z": 3,
"t": 4
};
var b = {
"x": 10,
"y": 11,
"z": 12
};

const requiredProps = ['x', 't'];
const verify = obj => requiredProps.every(prop => obj.hasOwnProperty(prop));

console.log(
verify(a),
verify(b)
);

关于javascript - 使用键或循环在 Javascript 中访问对象属性的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57387302/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com