手写lodash的get函数

以下是手写的 get 函数实现,用于安全地访问嵌套对象属性:

ini 复制代码
javascript
function get(obj, path, defaultValue) {
  // 将路径转换为数组形式
  const pathArray = Array.isArray(path)
    ? path
    : path.split(/.|$$|$$/).filter(p => p !== '');

  let current = obj;

  for (const key of pathArray) {
    if (current === null || current === undefined) {
      return defaultValue; // 遇到null/undefined立即返回默认值
    }
    current = current[key]; // 逐层访问属性
  }

  return current === undefined ? defaultValue : current;
}

实现说明:​

  1. 路径处理

    • path 是数组,直接使用。
    • path 是字符串,按 .[] 分割,并过滤空字符串。例如 'a[0].b' 会被转换为 ['a', '0', 'b']
  2. 逐层访问属性

    • 遍历路径数组,依次访问对象的属性。
    • 若中间遇到 nullundefined,直接返回默认值。
  3. 返回值处理

    • 最终值为 undefined 时返回 defaultValue,否则返回实际值。

示例用法:​

csharp 复制代码
javascript
const obj = { a: { b: [ { c: 3 } ] } };

console.log(get(obj, 'a.b.0.c')); // 3
console.log(get(obj, ['a', 'b', '0', 'c'])); // 3
console.log(get(obj, 'a.x', 'default')); // 'default'
console.log(get(null, 'a.b')); // undefined

注意事项:​

  • 属性名含 .[] 时,需使用数组形式路径(如 ['a.b', 'c'])。
  • 若需支持更复杂的路径(如带引号的字符串),需扩展路径解析逻辑。
相关推荐
dinl_vin12 分钟前
LangChain 系列·(九):Agent——让 AI 自己做决策
前端·人工智能·langchain
孟祥_成都12 分钟前
前端唯一的护城河?结合 AI 将字节组件库 Headless 化后的感想~
前端·人工智能·react.js
尽欢i20 分钟前
前端大坑!文件切片上传后端总报错找不到文件名?
前端·javascript
Sylvia33.22 分钟前
世界杯数据链路解析:从球场传感器到终端推送的毫秒级架构
java·前端·python·架构
镜宇秋霖丶27 分钟前
2026.5.10@霖宇博客制作中遇见的问题
前端·vue.js·elementui
ai超级个体30 分钟前
前端唯一的护城河?结合 AI 将字节组件库 Headless 化后的感想~
前端·react·ai编程·ant design·组件库·vibe coding
冴羽yayujs39 分钟前
前端周报:Remix 3、Node 26 与 Chrome 148
前端
问心无愧051339 分钟前
ctf show web 入门39
android·前端·笔记
卷无止境40 分钟前
Alpine.js入门笔记
前端
@王先生11 小时前
【K8S-ETCD初始化三节点集群】
前端·chrome·k8s·etcd·集群