Object.defineProperty()和Object.defineProperties()之间的性能差异

时间:2019-04-19 13:15:33

标签: javascript ecmascript-5 defineproperty

我正在寻找这两种方法之间的主要区别。

一些网站提到了可读性问题,但我主要担心的是性能问题。好像defineProperty()更快,但是我找不到原因。

var FOR_TIME = 10000;


console.time("prop");
for(var i = 0; i < FOR_TIME; i++) {
    var test = {};
    Object.defineProperty(test, "ba", {});
    Object.defineProperty(test, "bab", {});
    Object.defineProperty(test, "bac", {});
}
console.timeEnd("prop");

console.time("props");
for(var i = 0; i < FOR_TIME; i++) {
    var test = {};
    Object.defineProperties(test, {
        a: {},
        ab: {},
        ac: {}
    })
}
console.timeEnd("props");

这是控制台结果的结果:(执行了3次)

1- prop: 9.251ms props: 17.034ms
2- prop: 10.050ms props: 22.443ms
3- prop: 11.013ms props: 17.086ms

使用的节点版本:v10.15.0

1 个答案:

答案 0 :(得分:2)

您可以将基准读取为:“哦,defineProperty快两倍以上。”

或者您可以将其理解为:“即使defineProperties仅花费20毫秒进行10.000次迭代,这意味着它几乎不会引起任何问题,除非您在运行数千个循环的循环中创建数百万个实例次。”