Chaining

还记得jQuery支持链式调用吗?

  1. $('a').attr('target', '_blank')
  2. .append(' <i class="uk-icon-external-link"></i>')
  3. .click(function () {});

如果我们有一组操作,用underscore提供的函数,写出来像这样:

  1. _.filter(_.map([1, 4, 9, 16, 25], Math.sqrt), x => x % 2 === 1);
  2. // [1, 3, 5]

能不能写成链式调用?

能!

underscore提供了把对象包装成能进行链式调用的方法,就是chain()函数:

Chaining - 图1

因为每一步返回的都是包装对象,所以最后一步的结果需要调用value()获得最终结果。

小结

通过学习underscore,是不是对JavaScript的函数式编程又有了进一步的认识?

读后有收获可以支付宝请作者喝咖啡,读后有疑问请加微信群讨论:

Chaining - 图2 Chaining - 图3