「源码解读」知名程序员 TJ 的 only 库

大家好,我是前端西瓜哥。我最近尝试开启一个源码解读系列,不定期解读一些简单或复杂的源码。

今天要解读 npm 第三方库的源码:only,仓库地址为:https://github.com/tj/node-only

这个库是 tj 大神写的工具方法。tj 大神是一名程序员大佬,主要在 nodejs 领域做出了不少开源贡献,是 Express、Koa、node-canvas 等一系列知名开源项目的创建者和贡献者。

only 方法能干啥?

only 的功能很简单:返回一个对象的白名单属性。说具体点,就是提取指定对象的一些属性放到新对象里,并返回这个新对象。

const only = require('only');var obj = {
  name: 'tobi',
  last: 'holowaychuk',
  email: 'tobi@learnboost.com',
  _id: '12345'
};only(obj, 'name last email');
/* 
  {
    name: 'tobi',
    last: 'holowaychuk',
    email: 'tobi@learnboost.com'
  }
 */

only 方法要求传入一个对象,以及一个白名单列表,这个列表可以是属性名数组,也可以是通过空格间隔属性名表示的字符串。

第二个参数支持字符串格式,是因为使用更方便,能少写很多引号。使用上的优雅,是我们设计 API 时是需要做考量的。

only 库的实现

module.exports = function(obj, keys){
  obj = obj || {};
  if ('string' == typeof keys) keys = keys.split(/ +/);
  return keys.reduce(function(ret, key){
    if (null == obj[key]) return ret;
    ret[key] = obj[key];
    return ret;
  }, {});
};

代码解读

首先是对第一个参数 obj 做简单容错。如果 obj 是一个值为 undefined 或 null 之类的假值,我们就将其设置为一个空对象,防止抛出错误。

然后就是将可能是字符串形式的白名单转换为数组的格式。

使用的方法为:keys.split(/ +/),这里用到了 split 的正则表达式参数写法,/ +/ 这个正则表达式代表一个数量大于等于 1 的多个空格符。这其实是很常见的分割字符串拿到数组的写法。

最后用老鸟非常喜欢用的 Array.prototype.reduce() 的写法,来对 keys 数组进行迭代。

对于每个 key,只要原数组中不为 null 或 undefined,就将其浅拷贝到新对象中。

reduce() 方法的返回值就是我们要的新对象,直接将其返回。

我们再说说为什么一些资深前端喜欢用 reduce() 方法。其实是因为 reduce 这个方法相比 forEachmap 这些方法要更灵活,它能返回任何类型的值而写法不失简洁。 forEach 没有返回值,而 map 只能返回数组类型且大小相同的数组,虽然符合单一职责原则,但也因此失去了灵活性。

我曾经写过一篇关于 reduce 的文章,你感兴趣的话可以看看:为什么说数组实例的 reduce 方法灵活?

only 方法解读完毕。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Selenium是一个用于自动化浏览器操作的工具,它提供了一组API可以与各种浏览器进行交互。Selenium的源码解读可以帮助我们深入了解其内部实现原理和工作机制。 Selenium的源码主要由Java编写,整体结构分为三个部分:核心模块、浏览器驱动和客户端。 1. 核心模块:核心模块包含了Selenium的核心功能,如元素定位、页面操作、JavaScript执行等。其中,最重要的类是WebDriver接口,它定义了与浏览器交互的方法和属性。WebDriver接口的实现类包括ChromeDriver、FirefoxDriver等,它们通过与浏览器驱动进行通信来实现对浏览器的控制。 2. 浏览器驱动:浏览器驱动是Selenium与各种浏览器进行交互的桥梁。每种浏览器都需要对应的驱动程序来实现与Selenium的通信。例如,ChromeDriver用于与Chrome浏览器进行交互,FirefoxDriver用于与Firefox浏览器进行交互。浏览器驱动负责启动浏览器进程、发送命令给浏览器、获取页面内容等操作。 3. 客户端:Selenium支持多种编程语言,如Java、Python、C#等。每种语言都有对应的客户端,用于在代码中调用Selenium的功能。客户端提供了一组API,可以方便地进行元素定位、页面操作等操作。 如果你想深入了解Selenium的源码,可以从以下几个方面入手: 1. 研究WebDriver接口及其实现类的源码,了解与浏览器交互的具体实现方式。 2. 深入理解元素定位的原理和实现方式,包括XPath、CSS选择器等。 3. 学习浏览器驱动的源码,了解其启动浏览器进程、发送命令等操作。 4. 研究客户端源码,了解如何调用Selenium的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值