你可能不再需要Underscore
过去几年像 Underscore 和 lodash 等库进入许多JavaScript程序员的工具函数中。虽然这些工具库可以使你的代码写起来更容易,但是他们不一定使代码更简单或更容易理解。
各种工具函数库层出不穷,每个工具库的写法也各有不同,这样给阅读和维护你代码的人也带来了一定的困难,以为他必须了解你使用的这个这个工具库的函数做了什么事情。
JavaScript不断发展,新ES2015和ES2016版本(以前分别称为ES6和ES7)包了一堆新功能特性,并很容易使用它们。这些特性使得工具库以前的一些基本功能已经过时。
所以你可能不再需要Underscore。
例子:
这些例子说明,ES5.1,ES2015和ES2016做这些事情很容易,你可能不需要一个实用程序库了。ES5已经得到了所有现代浏览器和node.js的支持,要是想支持传统浏览器(比如IE8),还需要像es-shim这样的帮助脚本。
Arrays(数组)
Iterate(迭代)
- Underscore
- _.each(array, iteratee)
- ES5.1
- array.forEach(iteratee)
Map
- Underscore
- _.map(array, iteratee)
- ES5.1
- array.map(iteratee)
Find(查找)
- Underscore
- _.find(array, predicate)
- ES2015
- array.find(predicate)
Get a property from each element in an array(萃取数组对象中某属性值)
- Underscore(注:pluck也许是map最常使用的用例模型的简化版本,即萃取数组对象中某属性值,返回一个数组。)
- _.pluck(array, propertyName)
- ES2015
- array.map(value => value[propertyName])
Check if array includes an element(检查数组中是否包含某个元素)
- Underscore
- _.contains(array, element)
- ES2016
- array.includes(element)
Convert an array-like object to array(把一个类数组转换成一个数组)
- Underscore
- _.toArray(arguments)
- ES2015
- Array.from(arguments)
Create a copy of an array with all falsy values removed.(返回一个除去所有false值的 array副本)
- Underscore
- _.compact(array)
- ES2015
- array.filter(x => !!x)
Create a copy of an array with duplicates removed(返回 array去重后的副本)
- Underscore
- _.uniq(array)
- ES2015
- [...new Set(array)]
Find the index of a value in an array(查找某个值在 array 中的索引值)
- Underscore
- _.indexOf(array, value)
- ES5.1
- array.indexOf(value)
Create an array with n numbers, starting from x(创建一个 N个数字数组,从x开始)
- Underscore
- _.range(x, x + n)
- ES2015
- Array.from({ length: n }, (v, k) => k + x)
Objects(对象)
Names of own enumerable properties(枚举自身的属性名)
- Underscore
- _.keys(object)
- ES5.1
- Object.keys(object)
Names of all enumerable properties(枚举所有的属性名,包括继承过来的)
- Underscore
- _.allKeys(object)
- ES2015
- Reflect.enumerate(object) // 返回一个迭代器
Values(值)
- Underscore
- _.values(object)
- ES5.1
- Object.keys(object).map(key => object[key])
Create a new object with the given prototype(创建具有给定原型的新对象)
- Underscore
- _.create(proto, propertiesObject)
- ES5.1
- Object.create(proto, propertiesObject)
Create a new object from merged properties(创建一个合并属性后的新对象)
- Underscore
- _.extend({}, source, { a: false })
- ES2016
- { ...source, a: false }
Create a shallow clone of an object(创建一个浅拷贝对象)
- Underscore
- _.clone(object)
- ES2016
- { ...object }
Check if an object is an array(检查一个对象是否是一个数组)
- Underscore
- _.isArray(object)
- ES5.1
- Array.isArray(object)
Check if an object is a finite Number(检查一个对象是否是一个有限的数字)
- Underscore
- _.isFinite(object)
- ES2015
- Number.isFinite(object)
Functions(函数)
Bind a function to an object(给对象绑定一个函数)
- Underscore
- foo(function () {
- this.bar();
- }.bind(this));
- foo(_.bind(object.fun, object));
- ES2015
- foo(() => {
- this.bar();
- });
- foo(object.fun.bind(object));
- ES2016
- foo(() => {
- this.bar();
- });
- foo(::object.fun);
Utility(使用功能)
Identity function(迭代行数)
- Underscore
- _.identity
- ES2015
- value => value
A function that returns a value(返回值的函数)
- Underscore
- const fun = _.constant(value);
- ES2015
- const fun = () => value;
The empty function(空函数)
- Underscore
- _.noop()
- ES2015
- () => {}
任何疑问? Send us a pull request on GitHub!
PS:主要内容译自:https://www.reindex.io/blog/you-might-not-need-underscore
你可能不再需要Underscore的更多相关文章
- ES2015 (ES6)
是时候使用ES 2015了 你可能不再需要Underscore BABEL Grunt 先 babel 再用 babel 后的文件 uglify 去掉严格模式.严格模式下全局的this转成了undef ...
- underscore源码解析 (转载)
转载出自http://www.cnblogs.com/human/p/3273616.html (function() { // 创建一个全局对象, 在浏览器中表示为window对象, 在Node.j ...
- underscore源码解析
(function() { // 创建一个全局对象, 在浏览器中表示为window对象, 在Node.js中表示global对象 var root = this; // 保存"_" ...
- Underscore.js 源码学习笔记(下)
上接 Underscore.js 源码学习笔记(上) === 756 行开始 函数部分. var executeBound = function(sourceFunc, boundFunc, cont ...
- 跟着underscore学防抖
前言 在前端开发中会遇到一些频繁的事件触发,比如: window 的 resize.scroll mousedown.mousemove keyup.keydown -- 为此,我们举个示例代码来了解 ...
- Underscore.js部分讲解
underscore是非常好用的封装库,大小只有4KB,大多插件都是以underscore为基础: underscore分5大部分:集合:数组:函数:对象:工具 集合:集合就是伪数组,虽然长的和数组一 ...
- underscore.js源码解析(二)
前几天我对underscore.js的整体结构做了分析,今天我将针对underscore封装的方法进行具体的分析,代码的一些解释都写在了注释里,那么废话不多说进入今天的正文. 没看过上一篇的可以猛戳这 ...
- 利用Underscore求数组的交集、并集和差集
1 数组交集函数——intersection 数组的交集是指包含多个数组中的共同元素的一个数组,求数组的交集就是找出给定数组中的共有元素. 下面实现一个求两个数组交集的函数. 判断数组是够包含指定值, ...
- 理解Underscore中的节流函数
上一篇中讲解了Underscore中的去抖函数(_.debounced),这一篇就来介绍节流函数(_.throttled). 经过上一篇文章,我相信很多人都已经了解了去抖和节流的概念.去抖,在一段连续 ...
随机推荐
- python异步爬虫
本文主要包括以下内容 线程池实现并发爬虫 回调方法实现异步爬虫 协程技术的介绍 一个基于协程的异步编程模型 协程实现异步爬虫 线程池.回调.协程 我们希望通过并发执行来加快爬虫抓取页面的速度.一般的实 ...
- Lattice 的 Framebuffer IP核使用调试笔记之datasheet笔记
本文由远航路上ing 原创,转载请标明出处. 学习使用以及调试Framebuffer IP 核已经有一段时间了,调试的时候总想记录些东西,可是忙的时候就没有时间来写,只有先找个地方记录下,以后再总结. ...
- Jmeter测试JDBC
Datebase Driver class Database URL MySQL com.mysql.jdbc.Driver jdbc:mysql://host:port/{dbname} Postg ...
- jQuery – 6.选择器
1. 属性过滤选择器: 1. $("div[id]")选取有id属性的<div> 2. $("div[title=test]")选取title属性为 ...
- Linux获取当前用户信息函数
转自:http://net.pku.edu.cn/~yhf/linux_c/function/07.html endgrent(关闭组文件) 相关函数 getgrent,setgrent 表头文件 # ...
- 重温WCF之WCF传输安全(十三)(2)基于SSL的WCF匿名客户端(转)
转载地址:http://www.cnblogs.com/lxblog/archive/2012/09/13/2683514.html 这一篇我们利用上一篇制作的证书,来演示一个基于SSL的WCF服务, ...
- Delphi的面向对象编程基础笔记
1.面向对象.一门面向对象的编程语言至少要实现以下三个OOP的概念 封装:把相关的数据和代码结合在一起,并隐藏细节.封装的好处是利用程序的模块化,并把代码和其他代码分开 继承:是指一个新的类能够从父类 ...
- 攻城狮在路上(叁)Linux(十二)--- Linux的目录与路径
一.相对路径与绝对路径: A.绝对路径:由根目录/开始写起的路径,例如 /usr/share/doc B.相对路径:不是由根目录/开始写起的路径. 二.目录的相关操作: 1.cd: 目录切换 cd ~ ...
- golang debug with LiteIDE
golang 的调试比较麻烦,debug stop into 无法跳转到自己写的代码,但是能够跳转到系统提供的代码. 以下是简单的测试代码: package main import ( "f ...
- 直传文件到Azure Storage的Blob服务中
(此文章同时发表在本人微信公众号“dotNET每日精华文章”,欢迎右边二维码来关注.) 题记:为了庆祝获得微信公众号赞赏功能,忙里抽闲分享一下最近工作的一点心得:如何直接从浏览器中上传文件到Azure ...