underscore 函数式编程库


前面我们已经讲过了,JavaScript 是函数式编程语言,支持高阶函数和闭包。函数式编程非常强大,可以写出非常简洁的代码。例如 Array 的 map() 和 filter() 方法:

'use strict';
var a1 = [1, 4, 9, 16];
var a2 = a1.map(Math.sqrt); // [1, 2, 3, 4]
var a3 = a2.filter((x) => { return x % 2 === 0; }); // [2, 4]

现在问题来了,Array 有 map() 和 filter() 方法,可是 Object 没有这些方法。此外,低版本的浏览器例如 IE6~8 也没有这些方法,怎么办?
方法一,自己把这些方法添加到 Array.prototype 中,然后给 Object.prototype 也加上 mapObject() 等类似的方法。
方法二,直接找一个成熟可靠的第三方开源库,使用统一的函数来实现 map()、filter() 这些操作。
我们采用方法二,选择的第三方库就是 underscore。
正如 jQuery 统一了不同浏览器之间的 DOM 操作的差异,让我们可以简单地对 DOM 进行操作,underscore 则提供了一套完善的函数式编程的接口,让我们更方便地在 JavaScript 中实现函数式编程。
jQuery 在加载时,会把自身绑定到唯一的全局变量 $ 上,underscore 与其类似,会把自身绑定到唯一的全局变量 _ 上,这也是为啥它的名字叫 underscore 的原因。
用 underscore 实现 map() 操作如下:

'use strict';
_.map([1, 2, 3], (x) => x * x); // [1, 4, 9]

咋一看比直接用 Array.map() 要麻烦一点,可是 underscore 的 map() 还可以作用于 Object:

'use strict';
_.map({ a: 1, b: 2, c: 3 }, (v, k) => k + '=' + v); // ['a=1', 'b=2', 'c=3']

underscore Collections 集合类对象 >>
  • 作者 建站迷

    建站迷

    让天下没有难做的网站!
    解决中小型企业的无站之伤。



没有账号? 忘记密码?

社交账号快速登录