数组和对象的另类用法

以下是几种在 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() 的规则。
相关推荐
2601_958492556 小时前
Optimizing Engagement with Freehead Skate - HTML5 Game - Construct 3
前端·html·html5
茉莉玫瑰花茶7 小时前
工作流的常见模式 [ 1 ]
java·服务器·前端
zhangxingchao8 小时前
AI应用开发六:企业知识库
前端·人工智能·后端
山峰哥8 小时前
SQL慢查询调优实战:从全表扫描到索引覆盖的完整复盘
前端·数据库·sql·性能优化
红尘散仙8 小时前
一个 `#[uniffi::export]`,把 Rust 接进 React Native
前端·后端·rust
moshuying8 小时前
AI Coding 最大的 token 黑洞,可能根本不是 prompt
前端
红尘散仙8 小时前
一行 `#[specta::specta]`,让 Tauri IPC 有类型
前端·后端·rust
lichenyang4539 小时前
HarmonyOS HMRouter 接入记录:从普通 Tab Demo 到路由跳转
前端
木斯佳9 小时前
前端八股文面经大全:腾讯WXG暑期前端一面(2026-05-15)·面经深度解析
前端·面试·笔试