您现在的位置是:首页 > Javascript
当前栏目
Chaining
2023-02-18 15:28:54 时间
还记得jQuery支持链式调用吗?
$('a').attr('target', '_blank')
.append(' <i class="uk-icon-external-link"></i>')
.click(function () {});
如果我们有一组操作,用underscore提供的函数,写出来像这样:
_.filter(_.map([1, 4, 9, 16, 25], Math.sqrt), x => x % 2 === 1);
// [1, 3, 5]
能不能写成链式调用?
能!
underscore提供了把对象包装成能进行链式调用的方法,就是chain()
函数:
----
var r = _.chain([1, 4, 9, 16, 25])
.map(Math.sqrt)
.filter(x => x % 2 === 1)
.value();
----
console.log(r); // [1, 3, 5]
因为每一步返回的都是包装对象,所以最后一步的结果需要调用value()
获得最终结果。
小结
通过学习underscore,是不是对JavaScript的函数式编程又有了进一步的认识?
相关文章
- [日常] json_encode对中文和引号的处理差异研究
- [前端] js中call方法的理解和思考
- [javaEE] jsp的九大隐式对象
- [javaEE] jsp的指令
- [javaEE] jsp入门
- [javascript] Promise简单学习使用
- [android] WebView与Js交互
- [javascript] 看知乎学习js事件触发过程
- [javascript] 看知乎学习js闭包
- [angularjs] angularjs系列笔记(八)事件
- [angularjs] 前端路由实现单页跳转
- [angularjs] angularjs系列笔记(七)HTML DOM
- JS对象拷贝:深拷贝和浅拷贝
- [angularjs] angularjs系列笔记(六)http
- [angularjs] angularjs系列笔记(五)Service
- [angularjs] angularjs系列笔记(四)过滤器
- [angularjs] angularjs系列笔记(四)控制器
- [angularjs] angularjs系列笔记(三)模型
- [angularjs] angularjs系列笔记(二)指令
- [nodejs] nodejs开发个人博客(七)后台登陆