lodash-es中的set和get的用法

lodash-eslodash 的一个模块化版本,允许你通过 ES 模块(ECMAScript Modules)的方式按需导入函数,以减少最终打包体积。lodash 是一个一致性、模块化、高性能的 JavaScript 实用工具库。在 lodash-es 中,_.set_.get 是两个非常有用的函数,用于在深层嵌套的对象中安全地读取和设置值。

_.get

_.get 函数用于从对象或数组中按照路径获取值。如果路径不存在,可以返回默认值。这对于避免在深度嵌套的对象中访问不存在的属性时引发错误非常有用。

语法

javascript 复制代码
_.get(object, path, [defaultValue])
  • object (Object|Array):要查询的对象或数组。
  • path (Array|string):要查询的属性路径。字符串路径中的键可以使用点号(.)或方括号([])分隔。
  • [defaultValue] (*):如果解析的值是 undefined,则返回此值。

示例

javascript 复制代码
import { get } from 'lodash-es';

const object = { 'a': [{ 'b': { 'c': 3 } }] };

console.log(get(object, 'a[0].b.c'));
// => 3

console.log(get(object, ['a', '0', 'b', 'c']));
// => 3

console.log(get(object, 'a.b.c', 'default'));
// => 'default'

_.set

_.set 函数用于设置对象路径上的值。如果路径不存在,将创建它。这对于动态地向深层嵌套的对象添加属性非常有用。

语法

javascript 复制代码
_.set(object, path, value)
  • object (Object|Array):要修改的对象或数组。
  • path (Array|string):要设置的属性路径。字符串路径中的键可以使用点号(.)或方括号([])分隔。
  • value (*):要设置的值。

示例

javascript 复制代码
import { set } from 'lodash-es';

const object = { 'a': [{ 'b': { 'c': 3 } }] };

_.set(object, 'a[0].b.c', 4);
console.log(object.a[0].b.c);
// => 4

_.set(object, ['x', '0', 'y', 'z'], 5);
console.log(object.x[0].y.z);
// => 5

通过这两个函数,你可以灵活地在 JavaScript 对象或数组中读取和设置值,而无需担心路径是否存在。这在处理复杂的数据结构时特别有用。

相关推荐
1104.北光c°2 天前
【AI核心概念讲解】一口气搞懂 Agent:干翻传统后端!自主循环决策的秘密,ReAct 与 Plan-and-Execute 范式
java·人工智能·程序人生·ai·agent·react·智能体
DevilSeagull4 天前
电脑上安装的服务会自动消失? 推荐项目: localhostSCmanager. 更好管理你的服务!
测试工具·安全·react·vite·localhost·hono·trpc
钛态5 天前
前端TypeScript高级技巧:让你的代码更安全
前端·vue·react·web
钛态7 天前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
钛态7 天前
前端趋势:别被时代抛弃
前端·vue·react·web
迪普阳光开朗很健康8 天前
告别繁琐!用ApkInfoQuick快速提取APK关键信息
android·rust·react
Mr. zhihao9 天前
深入理解 ReAct 循环:从 LLM 决策到工具执行的完整闭环
python·ai·react
j_xxx404_10 天前
我用 Codex 做了一个智能围棋机器人系统:从 AI 引擎接入到前后端联调的完整实战
c++·人工智能·python·机器人·软件工程·团队开发·react
花千树-01011 天前
ReAct 思考-行动-观察循环的底层实现机制
langchain·agent·react·ai编程·ai agent·langgraph·mcp
花千树-01012 天前
ReAct Agent是什么?与传统LLM/Chatbot的本质区别(原理篇)
langchain·react·ai编程·chatbot·ai agent·langgraph·mcp