美文网首页小码农养成记
在 JavaScript 中 Object.assign 和 .

在 JavaScript 中 Object.assign 和 .

作者: F_wind | 来源:发表于2021-10-27 21:50 被阅读0次

    JavaScript , ES6

    先说结论:在大量合并的情况下,Object.assign 的性能要远高于 ...
    下面是笔者使用个人笔记本电脑在 Node.js 环境下跑的测试程序:

    function h1(n) {
        var timer = new Date().getTime()
        var obj = {}
        for (var i = 0; i < n; i++) {
            Object.assign(obj, { ['key' + i]: i })
        }
        return new Date().getTime() - timer
    }
    
    function h2(n) {
        var timer = new Date().getTime()
        var obj = {}
        for (var i = 0; i < n; i++) {
            obj = { ...obj, ['key' + i]: i }
        }
        return new Date().getTime() - timer
    }
    console.log('h1(10000):', h1(10000))
    console.log('h2(10000):', h2(10000))
    

    其中 h1 是用 Object.assign 实现的合并,h2 是用 ... 实现的合并,都是每次加一条属性,可以自定义添加属性的数量。下面是一个跑分情况:

    方式 10000 1000 100 10
    Object.assign 15 毫秒 3 毫秒 0 毫秒 0 毫秒
    ... 20755 毫秒 107 毫秒 0 毫秒 0 毫秒

    在实际应用场景中,一般很少会遇到连续地大量地添加对象添加属性的情形,虽然 ... 的性能更低一些,不过其写法更加优雅简洁,而且随着 ES 的不断迭代,其性能性能也可能会不断优化甚至解决掉因此使用任何一种方式都 ok。

    相关文章

      网友评论

        本文标题:在 JavaScript 中 Object.assign 和 .

        本文链接:https://www.haomeiwen.com/subject/vytmaltx.html