lodash-实用库及常用方法

news/2025/1/13 1:00:56 标签: 前端, javascript, vue.js

chunk():将数组(array)拆分成多个指定长度的区块,并将这些区块组成一个新数组。例如:

javascript">let array = [1, 2, 3, 4, 5, 6];
let chunked = _.chunk(array, 2); 
// [[1, 2], [3, 4], [5, 6]]

debounce():在执行回调函数之前,延迟执行该函数。常用于处理重复的实时事件,防止回调函数的频繁触发。

javascript">function savePreferences() {  
    // code to save preferences
}
let save = _.debounce(savePreferences, 1000);
// Set the preference and debounced function is called after 1 second with the preference value.save('my preference');

isObject():判断某个值是否为对象。

javascript">let isObject = _.isObject({}); // true
let isNotObject = _.isObject('string'); // false

isNaN():判断某个值是否为NaN。
isNaN函数用于检查一个值是否为“非数字”值。这意味着它可以用来检测一个值是否是NaN(Not a Number),或者是一个可以被解释为有效数字的其他非数字值。

javascript">const _ = require('lodash');

console.log(_.isNaN(NaN));               // 输出: true
console.log(_.isNaN(0));                  // 输出: false
console.log(_.isNaN(''));                 // 输出: false
console.log(_.isNaN('123'));               // 输出: false
console.log(_.isNaN([1, 2, 3]));           // 输出: false
console.log(_.isNaN({ a: 1, b: 2 }));      // 输出: false
console.log(_.isNaN(null));               // 输出: false
console.log(_.isNaN(undefined));          // 输出: false

isUndefined():判断某个值是否为undefined。

javascript">const _ = require('lodash');

let value1, value2, value3;

console.log(_.isUndefined(value1));  *// 输出: true*
console.log(_.isUndefined(value2));  *// 输出: false*
console.log(_.isUndefined(value3));  *// 输出: true*

map():创建一个新数组,数组中的元素是通过调用提供的函数在原始数组上产生的结果。

javascript">let array = [1, 2, 3];
let doubled = _.map(array, function(num) { return num * 2; }); 
// [2, 4, 6]

get():获取对象指定属性的值。

它允许你通过指定的路径获取对象的属性。如果路径不存在,则返回undefined

javascript">const _ = require('lodash');

let object = {
  a: {
    b: {
      c: 3
    }
  }
};

console.log(_.get(object, 'a.b.c')); // 输出 3
console.log(_.get(object, 'a.b.d')); // 输出 undefined
console.log(_.get(object, 'a.e')); // 输出 undefined

set():设置对象指定属性的值。

set函数是用于在对象中设置指定路径的属性值。如果路径不存在,则会自动创建。

javascript">const _ = require('lodash');

let object = {
  a: {
    b: {
      c: 3
    }
  }
};

_.set(object, 'a.b.c', 4); // 设置路径'a.b.c'的属性值为4
console.log(object); // 输出 { a: { b: { c: 4 } } }

_.set(object, 'a.b.d', 5); // 设置路径'a.b.d'的属性值为5,如果不存在会创建路径
console.log(object); // 输出 { a: { b: { c: 4, d: 5 } } }

isEqual():深度比较两个对象是否相等。

isEqual函数用于比较两个对象或值是否相等。它使用严格比较(deep comparison)来检查对象和数组中的值,并且会处理循环引用。

javascript">const _ = require('lodash');

let object1 = { a: 1, b: { c: 2 } };
let object2 = { a: 1, b: { c: 2 } };
let object3 = { a: 1, b: { c: 3 } };

console.log(_.isEqual(object1, object2));  // 输出: true
console.log(_.isEqual(object1, object3));  // 输出: false

isEmpty():判断一个对象是否为空。

isEmpty函数用于检查一个对象(数组、字符串、对象等)是否为空。

javascript">const _ = require('lodash');

let array1 = [];
let array2 = [1, 2, 3];
let object1 = {};
let object2 = { a: 1, b: 2 };
let string1 = '';
let string2 = 'abc';

console.log(_.isEmpty(array1));      // 输出: true
console.log(_.isEmpty(array2));      // 输出: false
console.log(_.isEmpty(object1));     // 输出: true
console.log(_.isEmpty(object2));     // 输出: false
console.log(_.isEmpty(string1));     // 输出: true
console.log(_.isEmpty(string2));     // 输出: false

sortBy(): 方法可以按照指定的条件对数组进行排序。

javascript">let people = [ 
    { 'name': 'John', 'age': 30 }, 
    { 'name': 'Jane', 'age': 25 }, 
    { 'name': 'Mike', 'age': 35 }
];
let sortedPeople = _.sortBy(people, ['age', 'name']);
console.log(sortedPeople);
// [{ name: 'Jane', age: 25 }, { name: 'John', age: 30 }, { name: 'Mike', age: 35 }]

在上面的例子中,我们首先定义了一个people数组,然后使用sortBy方法按照age和name进行排序。sortBy方法接受两个参数,第一个参数是需要排序的数组,第二个参数是一个字符串或数组,用于指定排序的条件。如果第二个参数是字符串,则按照该字符串代表的属性进行排序;如果第二个参数是数组,则先按照第一个元素指定的属性进行排序,然后按照第二个元素指定的属性进行排序。

需要注意的是,sortBy方法默认按照升序排序,如果需要按照降序排序,可以传入第三个参数为true。

union()函数用于合并多个数组,并去除重复项

javascript">// 导入lodash库
const _ = require('lodash');

// 创建数组
const array1 = [1, 2, 3];
const array2 = [3, 4, 5];
const array3 = [5, 6, 7];

// 使用union函数合并数组并去除重复项
const result = _.union(array1, array2, array3);

// 输出结果
console.log(result); // [1, 2, 3, 4, 5, 6, 7]

intersection()函数用于获取数组的交集

javascript">// 导入lodash库
const _ = require('lodash');

// 创建数组
const array1 = [1, 2, 3];
const array2 = [3, 4, 5];
const array3 = [5, 6, 7];

// 使用intersection函数获取数组的交集
const result = _.intersection(array1, array2, array3);

// 输出结果
console.log(result); // [3]

difference()函数用于从第一个数组中移除所有在其他数组中的元素

javascript">// 导入lodash库
const _ = require('lodash');

// 创建数组
const array1 = [1, 2, 3, 4, 5];
const array2 = [3, 4];
const array3 = [4, 5];

// 使用difference函数从array1中移除所有在array2和array3中的元素
const result = _.difference(array1, array2, array3);

// 输出结果
console.log(result); // [1]

pluck()从对象中获取给定键的值

javascript">const people = [{'name': 'Bob', 'age': 36}, {'name': 'Alice', 'age': 30}];
const names = _.pluck(people, 'name'); // ['Bob', 'Alice']

invoke()这个函数用于调用对象中的方法。这对于处理包含方法的对象非常有用。

javascript">const person = {
  name: 'John',
  age: 30,
  greet: function() {
    console.log('Hello!');
  }
};
_.invoke(person, 'greet'); // "Hello!"

assign()这个函数用于将对象的属性复制到另一个对象。这是一个非常有用的函数,用于合并对象。

javascript">const obj1 = { a: 1 };
const obj2 = { b: 2 };
const merged = _.assign({}, obj1, obj2); // { a: 1, b: 2 }

cloneDeep()这个函数用于深度克隆一个对象。这对于处理复杂对象和避免引用问题非常有用

javascript">const obj = { a: 1, b: { c: 2 } };
const cloned = _.cloneDeep(obj); // { a: 1, b: { c: 2 } }

http://www.niftyadmin.cn/n/5821365.html

相关文章

一文流:Maven精讲

一文流系列是作者苦于技术知识学了-忘了,背了-忘了的苦恼,决心把技术知识的要点一笔笔✍️出来,一图图画出来,一句句讲出来,以求刻在🧠里。 该系列文章会把核心要点提炼出来,以求掌握精髓&#…

unity学习15:预制体prefab

目录 1 创建多个gameobject 2 创建prefab 2.1 创建prefab (类) 2.2 prefab 是一个文件 2.3 prefab可以导出 3 创建prefab variant (子类) 3.1 除了创建多个独立的prefab, 还可以创建 prefab variant 3.2 他…

利用logstash同步100万MySQL数据到es

安装logstash和es这些看之前的一篇文章 第一步修改logstash.conf文件 input {jdbc {jdbc_driver_library > "/usr/share/logstash/lib/mysql-connector-j-8.0.33.jar"jdbc_driver_class > "com.mysql.cj.jdbc.Driver"jdbc_connection_string > …

RS-232串口和普通串口介绍

RS-232串口和普通串口的区别主要体现在标准和信号电平的不同,虽然“串口”通常指的是基于串行通信的接口,但不同的串口标准在硬件实现和使用场景上有些不同。 RS-232串口 vs 普通串口的区别 RS-232 是一种具体的串行通信协议标准,而“普通串口”这个词通常是指没有明确标准定…

计算机网络之---TCP报文段

TCP报文段 TCP报文段是TCP协议中传输数据的基本单位。TCP协议基于流控制、顺序控制和错误校验等机制,以确保数据的可靠传输。TCP报文段结构由多个字段组成,每个字段在TCP的工作中都有特定的作用 一个典型的TCP报文段由两部分组成: TCP头部&a…

基于多Agent串联与大模型理解能力的智能背单词系统

基于多Agent串联与大模型理解能力的智能背单词系统 摘要 传统的背单词软件往往采用机械重复的记忆方式,缺乏个性化和趣味性,导致用户学习效率低下。本文将介绍一种基于多Agent串联与大模型理解能力的智能背单词系统。该系统通过多个具备思考、记忆和决策能力的Agent协同工作…

安装yarn时显示npm使用淘宝镜像安装报错

问题描述: npm使用淘宝镜像安装报错 错误原因: 淘宝原镜像域名(registry.npm.taobao.org)的 HTTPS 证书正式到期,npm 淘宝镜像已经从 registry.npm.taobao.org 切换到了 registry.npmmirror.com。解决方案:…

【JAVA面试】java权限修饰符

在 Java 中,访问权限(Access Modifiers)用于控制类、方法、成员变量等的访问范围。合理使用访问权限能够增强代码的安全性、封装性以及可维护性。 Java 的访问权限修饰符 Java 提供了以下四种访问权限修饰符,分别是: …