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. 代码复用:作为基础函数被多个上层函数使用
相关推荐
reasonsummer3 分钟前
【办公类-133-02】20260319_学区化展示PPT_02_python(图片合并文件夹、提取同名图片归类文件夹、图片编号、图片GIF)
前端·数据库·powerpoint
胡耀超18 分钟前
Web Crawling 网络爬虫全景:技术体系、反爬对抗与全链路成本分析
前端·爬虫·python·网络爬虫·数据采集·逆向工程·反爬虫
阿明的小蝴蝶22 分钟前
记一次Gradle环境的编译问题与解决
android·前端·gradle
Ruihong24 分钟前
【VuReact】轻松实现 Vue 到 React 路由适配
前端·react.js
山_雨25 分钟前
startViewTransition
前端
写代码的【黑咖啡】28 分钟前
Python Web 开发新宠:FastAPI 全面指南
前端·python·fastapi
凉_橙28 分钟前
gitlab CICD
前端
wangfpp30 分钟前
性能优化,请先停手:为什么我劝你别上来就搞优化?
前端·javascript·面试
踩着两条虫32 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(二十):CLI与工具链之构建配置与Vite集成
前端·vue.js·ai编程
凉_橙33 分钟前
前端项目与node项目部署记录
前端