数组和对象的另类用法

以下是几种在 JavaScript 中获取数组第一位的方法:

1. ‌直接索引访问

ini 复制代码
const arr = [10, 20, 30];
const first = arr; // 10
  • 特点‌:最简洁、高效,直接通过索引访问。
  • 注意 ‌:如果数组为空,返回 undefined

2. ‌使用 Array.prototype.shift()

ini 复制代码
const arr = [10, 20, 30];
const first = arr.shift(); // 10
// 此时 arr 变为 [20, 30]
  • 特点 ‌:返回第一个元素,但会‌修改原数组‌(移除第一位)。
  • 适用场景‌:需要同时删除第一个元素时。

3. ‌使用 Array.prototype.slice()

ini 复制代码
const arr = [10, 20, 30];
const first = arr.slice(0, 1); // 10
// 或直接解构:const [first] = arr.slice();
  • 特点 ‌:返回新数组(包含第一个元素),‌不修改原数组‌。
  • 注意 ‌:如果数组为空,slice(0,1) 返回空数组,此时 `` 为 undefined

4. ‌解构赋值(Destructuring)

ini 复制代码
const arr = [10, 20, 30];
const [first] = arr; // first = 10
  • 特点 ‌:语法简洁(ES6+),‌不修改原数组‌。
  • 注意 ‌:如果数组为空,firstundefined

5. ‌使用 Array.prototype.at()(ES2022+)

ini 复制代码
const arr = [10, 20, 30];
const first = arr.at(0); // 10
  • 特点 ‌:支持负数索引(如 arr.at(-1) 获取最后一个元素),‌不修改原数组‌。
  • 兼容性‌:需较新浏览器或 Node.js 16+。

以下是几种在 JavaScript 中获取对象第一位的方法:

1. ‌使用 Object.keys() 取第一个键

ini 复制代码
const obj = { a: 10, b: 20, c: 30 };
const firstKey = Object.keys(obj); // 'a'
const firstValue = obj[firstKey]; // 10
  • 特点‌:直接获取第一个键,再通过键取值。
  • 注意 ‌:若对象为空,firstKeyundefined

2. ‌使用 for...in 循环取第一个属性

ini 复制代码
const obj = { a: 10, b: 20, c: 30 };
let firstValue;
for (const key in obj) {
  if (obj.hasOwnProperty(key)) { // 避免原型链上的属性
    firstValue = obj[key];
    break;
  }
}
console.log(firstValue); // 10
  • 特点‌:兼容性较好,但需手动终止循环。
  • 注意 ‌:若对象包含数字键(如 '1'),顺序可能与预期不同(数字键升序优先)。

3. ‌使用 Object.entries() 转数组取第一个键值对

css 复制代码
const obj = { a: 10, b: 20, c: 30 };
const [firstEntry] = Object.entries(obj); // ['a', 10]
const [key, value] = firstEntry || []; // key='a', value=10
  • 特点‌:直接获取第一个键值对组成的数组。
  • 注意 ‌:若对象为空,firstEntryundefined

4. ‌使用 Reflect.ownKeys()(ES6+)

ini 复制代码
const obj = { a: 10, 2: '数字键', b: 20 };
const firstKey = Reflect.ownKeys(obj); // '2'(数字键优先升序)
const firstValue = obj[firstKey]; // '数字键'
  • 特点‌:包含所有自有属性(含 Symbol 类型),且数字键会升序排列。
  • 注意‌:顺序规则:数字键升序 → 字符串键插入顺序 → Symbol 键插入顺序。

总结

  • 推荐 Object.keys(obj) ‌:简单直观,兼容性好。
  • 若需键值对,用 Object.entries(obj)
  • 需要兼容数字键顺序时,注意 Reflect.ownKeys() 的规则。
相关推荐
leobertlan1 小时前
2025年终总结
前端·后端·程序员
子兮曰1 小时前
OpenClaw架构揭秘:178k stars的个人AI助手如何用Gateway模式统一控制12+通讯频道
前端·javascript·github
百锦再2 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
莲华君2 小时前
React快速上手:从零到项目实战
前端·reactjs教程
百锦再2 小时前
React编程高级主题:测试代码
android·前端·javascript·react.js·前端框架·reactjs
易安说AI2 小时前
Ralph Loop 让Claude无止尽干活的牛马...
前端·后端
颜酱3 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
失忆爆表症4 小时前
05_UI 组件库集成指南:Shadcn/ui + Tailwind CSS v4
前端·css·ui
小迷糊的学习记录4 小时前
Vuex 与 pinia
前端·javascript·vue.js
发现一只大呆瓜4 小时前
前端性能优化:图片懒加载的三种手写方案
前端·javascript·面试