Lodash源码阅读-baseGetAllKeys

Lodash 源码阅读-baseGetAllKeys

概述

baseGetAllKeys 是 Lodash 中一个内部工具函数,用于获取对象的所有可枚举属性名(包括普通属性和 Symbol 属性)。它是 _.keys_.keysIn 等函数的基础实现。

前置学习

依赖函数

  • isArray:判断值是否为数组
  • arrayPush:将数组元素添加到目标数组中
  • keysFunc:获取对象可枚举属性名的函数(如 Object.keys
  • symbolsFunc:获取对象 Symbol 属性名的函数(如 Object.getOwnPropertySymbols

技术知识

  • JavaScript 对象属性类型(普通属性、Symbol 属性)
  • 可枚举性(enumerable)概念
  • 数组操作
  • 对象属性遍历方法

源码实现

javascript 复制代码
function baseGetAllKeys(object, keysFunc, symbolsFunc) {
  var result = keysFunc(object);
  return isArray(object) ? result : arrayPush(result, symbolsFunc(object));
}

实现思路

baseGetAllKeys 函数的实现思路是:

  1. 首先获取对象的所有可枚举属性名
  2. 然后根据对象类型决定是否添加 Symbol 属性名
  3. 如果是数组,直接返回属性名数组
  4. 如果不是数组,将 Symbol 属性名添加到结果数组中

源码解析

参数说明

javascript 复制代码
function baseGetAllKeys(object, keysFunc, symbolsFunc)
  • object:要获取属性名的对象
  • keysFunc:获取普通属性名的函数(如 Object.keys
  • symbolsFunc:获取 Symbol 属性名的函数(如 Object.getOwnPropertySymbols

获取普通属性名

javascript 复制代码
var result = keysFunc(object);
  • 调用传入的 keysFunc 获取对象的所有可枚举属性名
  • 结果存储在 result 数组中

条件判断和 Symbol 属性处理

javascript 复制代码
return isArray(object) ? result : arrayPush(result, symbolsFunc(object));
  • 使用三元运算符判断对象是否为数组
  • 如果是数组,直接返回 result
  • 如果不是数组,使用 arrayPush 将 Symbol 属性名添加到 result

总结

实现特点

  1. 灵活性:通过参数传入不同的属性获取函数,支持不同的属性获取策略
  2. 类型区分:对数组和普通对象采用不同的处理方式
  3. 完整性:同时获取普通属性和 Symbol 属性
  4. 性能优化:避免对数组进行不必要的 Symbol 属性处理

设计原则

  1. 单一职责原则:专注于获取对象的所有属性名
  2. 开闭原则:通过参数传入不同的函数,支持扩展不同的属性获取方式
  3. 代码复用:作为基础函数被多个上层函数使用
相关推荐
这儿有一堆花12 分钟前
网站链接重定向原理
前端
cecyci21 分钟前
如何实现AI聊天机器人的打字机效果?
前端·javascript
IT_陈寒24 分钟前
Vite 5个隐藏技巧让你的项目构建速度提升50%,第3个太香了!
前端·人工智能·后端
詩句☾⋆᭄南笙33 分钟前
HTML的盒子模型
前端·html·盒子模型
落言35 分钟前
AI 时代的工程师:懂,却非懂的时代
前端·程序员·架构
一枚攻城狮37 分钟前
前端知识点大汇总
前端
余道各努力,千里自同风2 小时前
el-input 输入框宽度自适应宽度
javascript·vue.js·elementui
Mike_jia2 小时前
DumbAssets:开源资产管理神器,家庭与企业的高效管家
前端
Southern Wind2 小时前
Vue 3 多实例 + 缓存复用:理念及实践
前端·javascript·vue.js·缓存·html
HuangYongbiao3 小时前
Rspack 原理:webpack,我为什么不要你
前端