还记得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()函数:

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

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

小结

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