JavaScript之underscore_动力节点Java学院整理
程序员文章站
2023-10-31 18:41:22
javascript是函数式编程语言,支持高阶函数和闭包。函数式编程非常强大,可以写出非常简洁的代码。例如array的map()和filter()方法:
'use...
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']
下一篇: 可乐怎么做的,做什么菜好吃
推荐阅读
-
apache简介_动力节点Java学院整理
-
Spring MVC之DispatcherServlet详解_动力节点Java学院整理
-
Spring MVC之DispatcherServlet_动力节点Java学院整理
-
linux下安装memcached_动力节点Java学院整理
-
Apache和Tomcat有什么区别_动力节点Java学院整理
-
JavaScript之RegExp_动力节点Java学院整理
-
JavaScript原型继承_动力节点Java学院整理
-
JavaScript之underscore_动力节点Java学院整理
-
JavaScript之DOM_动力节点Java学院整理
-
JavaScript之promise_动力节点Java学院整理