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. 代码复用:作为基础函数被多个上层函数使用
相关推荐
一笑code3 分钟前
UC浏览器PC版自2016年后未再更新不支持vue3
前端·vue
好记性不如27 分钟前
在前端项目中是如何解决跨域的
前端
前端 贾公子7 小时前
pnpm 的 resolution-mode 配置 ( pnpm 的版本解析)
前端
伍哥的传说8 小时前
React 自定义Hook——页面或元素滚动到底部监听 Hook
前端·react.js·前端框架
麦兜*10 小时前
Spring Boot 集成Reactive Web 性能优化全栈技术方案,包含底层原理、压测方法论、参数调优
java·前端·spring boot·spring·spring cloud·性能优化·maven
Jinkxs10 小时前
JavaScript性能优化实战技术
开发语言·javascript·性能优化
知了一笑10 小时前
独立开发第二周:构建、执行、规划
java·前端·后端
UI前端开发工作室10 小时前
数字孪生技术为UI前端提供新视角:产品性能的实时模拟与预测
大数据·前端
Sapphire~10 小时前
重学前端004 --- html 表单
前端·html
Maybyy11 小时前
力扣242.有效的字母异位词
java·javascript·leetcode