问答

这句JS代码是什么意思?

作者:admin 2021-05-14 我要评论

const pluckDeep = key = obj = key.split('.').reduce((accum, key) = accum[key], obj) ### 就是取嵌套属性值: let data = { a: { b: { c: { d: 1 } } }}pluc...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

image.png

const pluckDeep = key => obj => key.split('.').reduce((accum, key) => accum[key], obj)
###

就是取嵌套属性值:

let data = {
  a: {
    b: {
      c: {
        d: 1
      }
    }
  }
}

pluckDeep('a.b.c.d')(data) //返回1

说实话写得极其糟糕,这样的代码短但并不简洁,并且没处理空值。

好的代码,应该易读、易用,并且健壮。

如果实现这样一个接口,暴露给外部应该是直接接收2个参数:obj和keyString。而不是像现在接收一个参数,返回一个函数,再接收一个参数,再返回结果,反直观思维。

###
var pluckDeep = function pluckDeep(key) {
  return function (obj) {
    return key.split('.').reduce(function (accum, key) {
      return accum[key];
    }, obj);
  };
};
###

看上去就是根据字符串来取深层对象。

类似于 lodash 的 _.get 方法,但是没处理空指针问题。

比如有一个对象:

let obj = { a: { b: { c: 'HelloWorld' } } }

取值的时候可以:

let val = pluckDeep('a.b.c')(obj); // HelloWorld

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 请问下prometheus怎么进行自定义的按业

    请问下prometheus怎么进行自定义的按业

  • 节流函数为什么,点击无效,监听窗口大

    节流函数为什么,点击无效,监听窗口大

  • express访问静态资源失败

    express访问静态资源失败

  • IE 浏览器下 match 方法报错

    IE 浏览器下 match 方法报错

腾讯云代理商
海外云服务器