您现在的位置是:首页 > Javascript
当前栏目
underscore
2023-02-18 15:29:02 时间
前面我们已经讲过了,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提供了一系列函数式接口。
相关文章
- [javascript] 获取正则子表达式里的内容
- [vuejs] 聊天框在overflow:auto中填数据时滚动到底部
- [vuejs] 在vuejs中使用websocket进行实时通讯
- [javascript] elemetui布局中分栏间隔的问题
- [javascript] js判断对象类型typeof与instanceof解决elementui时间插件默认时间问题
- [javascript] 格式化日期为yyyymmdd格式
- [javascript] 实现展开全文和收起全文效果
- [javascript] vuejs先循环中实现点击后的选中状态
- [javascript] js判断变量要考虑undefine
- [javascript] vuejs媒资库项目展示
- [javascript] vuejs为输入框增加回车事件
- [javascript] elementui下el-switch组件的使用
- [javascript] vuejs的elementui实现父子iframe通信
- [javascript] npx 命令简单使用
- [javascript] vue的实例生命周期钩子函数
- [javascript] var let const声明变量的区别
- [javascript] vue3.0 beta版发布使用TS重写
- [javascript] 主流浏览器对ES6的支持情况
- [javascript] typescript的安装
- [MySQL] BLOB, TEXT, GEOMETRY or JSON column 'body' can't have a default value错误