lodash源码分析每日一练 - 数组 - fromPairs

今日分享:

每一步都是曼妙的风景~

_.fromPairs(pairs)

使用:

这个方法返回一个由键值对pairs构成的对象。

使用示例:

js 复制代码
_.fromPairs([['fred', 30], ['barney', 40]]);
// => { 'fred': 30, 'barney': 40 }

尝试手写:

①返回新对象 ②入参为由键值对构成的数组

js 复制代码
    let frompairs_arr = [['fred', 30], ['barney', 40]];
    function my_fromPairs (pairs) {
        let obj = {};
        if((pairs instanceof Array) && pairs.length>0) {
            for(let i = 0; i < pairs.length; i++) {
                obj[pairs[i][0]] = pairs[i][1]
            }
        }
        return obj;
    }
    console.log(my_fromPairs(frompairs_arr));// { 'fred': 30, 'barney': 40 }

源码方案:

js 复制代码
function fromPairs(pairs) {
  var index = -1,
      length = pairs == null ? 0 : pairs.length,
      result = {};

  while (++index < length) {
    var pair = pairs[index];
    result[pair[0]] = pair[1];
  }
  return result;
}

备注

为什么他都用 while 而不是for

语法糖只便于开发者理解而机器需要编译还原为简单的基础语言才能使用。可以说上我看的这个node_modules中的源码也是反编译后的结果而不是lodash源码。所以他的所有"源码"都是反编译后的内容。

其他

与之对应还有一个 _.toPairs(object) ,用于创建一个object对象自身可枚举属性的键值对数组。不放这里了,放后面object整理的时候吧。

相关推荐
悟能不能悟2 小时前
java的java.sql.Date和java.util.Date的区别,应该怎么使用
java·开发语言
循环过三天2 小时前
3.4、Python-集合
开发语言·笔记·python·学习·算法
_院长大人_3 小时前
设计模式-工厂模式
java·开发语言·设计模式
MATLAB代码顾问3 小时前
MATLAB实现决策树数值预测
开发语言·决策树·matlab
devincob4 小时前
js原生、vue导出、react导出、axios ( post请求方式)跨平台导出下载四种方式的demo
javascript·vue.js·react.js
编程社区管理员4 小时前
React 发送短信验证码和验证码校验功能组件
前端·javascript·react.js
葡萄城技术团队4 小时前
迎接下一代 React 框架:Next.js 16 核心能力解读
javascript·spring·react.js
全马必破三5 小时前
React“组件即函数”
前端·javascript·react.js
三思而后行,慎承诺5 小时前
React 底层原理
前端·react.js·前端框架
座山雕~5 小时前
html 和css基础常用的标签和样式
前端·css·html