当前位置:首页 > 科技  > 软件

你还在用sort排序?分享30个用的最频繁的lodash工具函数

来源: 责编: 时间:2024-04-28 17:19:04 262观看
导读前言大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心。事情起因是,有几个小伙伴在对一个数据进行排序,做了激烈的讨论,这组数据,想要根据num字段进行排序~把我气的,你们就不能直接

前言

大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心。pyC28资讯网——每日最新资讯28at.com

事情起因是,有几个小伙伴在对一个数据进行排序,做了激烈的讨论,这组数据,想要根据num字段进行排序~把我气的,你们就不能直接用lodash的sortBy吗?你们再怎么实现,能实现得比lodash好?pyC28资讯网——每日最新资讯28at.com

const arr = [    {num: 3,name: 'hh'},    {num: 1,name: 'xx'},    {num: 2,name: 'aa'}]// 使用lodashconsole.log(_.sortBy(arr, ['num']))

所以,我觉得有必要跟各位小伙伴分享一下,我在项目中用的最多的30个lodash工具方法pyC28资讯网——每日最新资讯28at.com

注:此文是总结一些常用的lodash方法,案例从文档拿的,介意的朋友请勿看~pyC28资讯网——每日最新资讯28at.com

我要对数组进行一系列操作!

取「交集」!

intersection

返回一个包含所有传入数组交集元素的新数组。pyC28资讯网——每日最新资讯28at.com

_.intersection([2, 1], [4, 2], [1, 2]);  // => [2]

intersectionBy

根据某个字段来进行计算交集pyC28资讯网——每日最新资讯28at.com

_.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');  // => [{ 'x': 1 }]

intersectionWith

根据某个条件函数来计算交集,比如使用isEqualpyC28资讯网——每日最新资讯28at.com

var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];  var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];    _.intersectionWith(objects, others, _.isEqual);  // => [{ 'x': 1, 'y': 2 }]

取「合集」!

union

返回一个新的联合数组。pyC28资讯网——每日最新资讯28at.com

_.union([2], [1, 2]);  // => [2, 1]

unionBy

根据某个字段来计算合集pyC28资讯网——每日最新资讯28at.com

_.unionBy([{ 'x': 1, 'y': 5 }], [{ 'x': 2, 'y': 3 }, { 'x': 1, 'y': 6 }], 'x');  // => [{ 'x': 1, 'y': 5 }, { 'x': 2, 'y': 3 }]

unionWith

根据某个条件函数来计算合集pyC28资讯网——每日最新资讯28at.com

var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];  var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];    _.unionWith(objects, others, _.isEqual);  // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]

取「差集」!

同上面两种工具函数,这里无需多言~pyC28资讯网——每日最新资讯28at.com

  • difference
  • differenceBy
  • differenceWith

取数组「总和」!

sum

返回总和。pyC28资讯网——每日最新资讯28at.com

_.sum([4, 2, 8, 6]);  // => 20

sumBy

根据某个字段计算并返回总和。pyC28资讯网——每日最新资讯28at.com

var objects = [{ 'n': 4 }, { 'n': 2 }, { 'n': 8 }, { 'n': 6 }];    _.sumBy(objects, function(o) { return o.n; });  // => 20    // The `_.property` iteratee shorthand.  _.sumBy(objects, 'n');  // => 20

取「平均数」!

mean

计算平均数pyC28资讯网——每日最新资讯28at.com

_.mean([4, 2, 8, 6]);  // => 5

meanBy

根据某个字段计算出平均值pyC28资讯网——每日最新资讯28at.com

var objects = [{ 'n': 4 }, { 'n': 2 }, { 'n': 8 }, { 'n': 6 }];    _.meanBy(objects, function(o) { return o.n; });  // => 5    // The `_.property` iteratee shorthand.  _.meanBy(objects, 'n');  // => 5

根据字段或条件「排序」!

sortBy

var users = [  { 'user': 'fred', 'age': 48 },  { 'user': 'barney', 'age': 36 },  { 'user': 'fred', 'age': 40 },  { 'user': 'barney', 'age': 34 }  ];    _.sortBy(users, function(o) { return o.user; });  // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]    _.sortBy(users, ['user', 'age']);  // => objects for [['barney', 34], ['barney', 36], ['fred', 40], ['fred', 48]]    _.sortBy(users, 'user', function(o) {  return Math.floor(o.age / 10);  });  // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]

超级实用的工具函数!

我要「浅拷贝」!

clone

const obj1 = [{a: 1 }]const obj2 = _.clone(obj1)console.log(obj1 === obj2) // falseconsole.log(obj1.a === obj2.a) // true

我要「深拷贝」!

cloneDeep

const obj1 = [{a: 1 }]const obj2 = _.cloneDeep(obj1)console.log(obj1 === obj2) // falseconsole.log(obj1.a === obj2.a) // false

debounce 我要「防抖」!

参数

  1. func  (Function)
  2. [wait=0]  (number)
  3. [optinotallow=]  (Object)
  4. [options.leading=false]  (boolean)
  5. [options.maxWait]  (number) : 设置 func 允许被延迟的最大值。
  6. [options.trailing=true]  (boolean)

返回

(Function)pyC28资讯网——每日最新资讯28at.com

例子

// 避免窗口在变动时出现昂贵的计算开销。jQuery(window).on('resize', _.debounce(calculateLayout, 150)); // 当点击时 `sendMail` 随后就被调用。jQuery(element).on('click', _.debounce(sendMail, 300, {  'leading': true,  'trailing': false})); // 确保 `batchLog` 调用1次之后,1秒内会被触发。var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });var source = new EventSource('/stream');jQuery(source).on('message', debounced); // 取消一个 trailing 的防抖动调用jQuery(window).on('popstate', debounced.cancel);

throttle 我要「节流」!

参数

  1. func  (Function)
  2. [wait=0]  (number)
  3. [optinotallow=]  (Object)
  4. [options.leading=true]  (boolean)
  5. [options.trailing=true]  (boolean)

返回

(Function)pyC28资讯网——每日最新资讯28at.com

例子

// 避免在滚动时过分的更新定位jQuery(window).on('scroll', _.throttle(updatePosition, 100)); // 点击后就调用 `renewToken`,但5分钟内超过1次。var throttled = _.throttle(renewToken, 300000, { 'trailing': false });jQuery(element).on('click', throttled); // 取消一个 trailing 的节流调用。jQuery(window).on('popstate', throttled.cancel);

我「获取」对象中的某几个字段!

pick

var object = { 'a': 1, 'b': '2', 'c': 3 };    _.pick(object, ['a', 'c']);  // => { 'a': 1, 'c': 3 }

我要「剔除」掉对象中的某几个字段!

omit

var object = { 'a': 1, 'b': '2', 'c': 3 };    _.omit(object, ['a', 'c']);  // => { 'b': '2' }

我要判断一个变量的类型!

isUndefined

如果 value 是 undefined ,那么返回 true,否则返回 falsepyC28资讯网——每日最新资讯28at.com

_.isUndefined(undefined);  // => true    _.isUndefined(null);  // => false

isNull

如果 value 为null,那么返回 true,否则返回 false。pyC28资讯网——每日最新资讯28at.com

_.isNull(null);  // => true    _.isNull(undefined);  // => false

isString

如果 value 为一个字符串,那么返回 true,否则返回 false。pyC28资讯网——每日最新资讯28at.com

_.isString('abc');  // => true    _.isString(1);  // => false

isPlainObject

如果 value 为一个普通对象,那么返回 true,否则返回 false。pyC28资讯网——每日最新资讯28at.com

function Foo() {  this.a = 1;  }    _.isPlainObject(new Foo);  // => false    _.isPlainObject([1, 2, 3]);  // => false    _.isPlainObject({ 'x': 0, 'y': 0 });  // => true    _.isPlainObject(Object.create(null));  // => true

isNumber

如果 value 为一个数值,那么返回 true,否则返回 false。pyC28资讯网——每日最新资讯28at.com

_.isNumber(3);  // => true    _.isNumber(Number.MIN_VALUE);  // => true    _.isNumber(Infinity);  // => true    _.isNumber('3');  // => false

isArray

如果value是一个数组返回 true,否则返回 false。pyC28资讯网——每日最新资讯28at.com

_.isArray([1, 2, 3]);  // => true    _.isArray(document.body.children);  // => false    _.isArray('abc');  // => false    _.isArray(_.noop);  // => false

isBoolean

如果 value 是一个布尔值,那么返回 true,否则返回 false。pyC28资讯网——每日最新资讯28at.com

_.isBoolean(false);  // => true    _.isBoolean(null);  // => false

isFunction

如果 value 是一个函数,那么返回 true,否则返回 false。pyC28资讯网——每日最新资讯28at.com

_.isFunction(function(){});  // => true    _.isFunction('');  // => false

isNill

如果 value 为null 或 undefined,那么返回 true,否则返回 false。pyC28资讯网——每日最新资讯28at.com

_.isNil(null);  // => true    _.isNil(void 0);  // => true    _.isNil(NaN);  // => fals


pyC28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-86206-0.html你还在用sort排序?分享30个用的最频繁的lodash工具函数

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Next.js 14 初学者指南

下一篇: 探索MVVM Toolkit:简化.NET应用开发,构建高效MVVM架构

标签:
  • 热门焦点
  • 影音体验是真的强 简单聊聊iQOO Pad

    大公司的好处就是产品线丰富,非常细分化的东西也能给你做出来,例如早先我们看到了新的vivo Pad2,之后我们又在iQOO Neo8 Pro的发布会上看到了iQOO的首款平板产品iQOO Pad。虽
  • 小米平板5 Pro 12.4简评:多专多能 兼顾影音娱乐的大屏利器

    疫情带来了网课,网课盘活了安卓平板,安卓平板市场虽然中途停滞了几年,但好的一点就是停滞的这几年行业又有了新的发展方向,例如超窄边框、高刷新率、多摄镜头组合等,这就让安卓
  • 6月安卓手机性能榜:vivo/iQOO霸占旗舰排行榜前三

    2023年上半年已经正式过去了,我们也迎来了安兔兔V10版本,在新的骁龙8Gen3和天玑9300发布之前,性能榜的榜单大体会以骁龙8Gen2和天玑9200+为主,至于那颗3.36GHz的骁龙8Gen2领先
  • 在线图片编辑器,支持PSD解析、AI抠图等

    自从我上次分享一个人开发仿造稿定设计的图片编辑器到现在,不知不觉已过去一年时间了,期间我经历了裁员失业、面试找工作碰壁,寒冬下一直没有很好地履行计划.....这些就放在日
  • ESG的面子与里子

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之三伏大幕拉起,各地高温预警不绝,但处于厄尔尼诺大“烤”之下的除了众生,还有各大企业发布的ESG报告。ESG是“环境保
  • 阿里大调整

    来源:产品刘有媒体报道称,近期淘宝天猫集团启动了近年来最大的人力制度改革,涉及员工绩效、层级体系等多个核心事项,目前已形成一个初步的“征求意见版”:1、取消P序列
  • 年轻人的“职场羞耻感”,无处不在

    作者:冯晓亭 陶 淘 李 欣 张 琳 马舒叶来源:燃次元“人在职场,应该选择什么样的着装?”近日,在网络上,一个与着装相关的帖子引发关注,在该帖子里,一位在高级写字楼亚洲金
  • 华为HarmonyOS 4升级计划公布:首批34款机型今日开启公测

    8月4日消息,今天下午华为正式发布了HarmonyOS 4系统,在更流畅的前提下,还带来了不少新功能,UI设计也有变化,会让手机焕然一新。华为宣布,首批机型将会在
  • 华为和江淮汽车合作开发百万元问界MPV?双方回应来了

    8月1日消息,郭明錤今天在社交平台发文称,华为正在和江淮汽车合作,开发售价在100万元的问界MPV,预计在2024年第2季度量产,销量目标为上市首年交付5万辆。
Top