数组和对象的另类用法

以下是几种在 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() 的规则。
相关推荐
深职第一突破口喜羊羊9 分钟前
记一次electron开发插件市场遇到的问题
javascript·electron
cypking17 分钟前
electron中IPC 渲染进程与主进程通信方法解析
前端·javascript·electron
西陵23 分钟前
Nx带来极致的前端开发体验——借助playground开发提效
前端·javascript·架构
江城开朗的豌豆38 分钟前
Element UI动态组件样式修改小妙招,轻松拿捏!
前端·javascript·vue.js
float_六七1 小时前
JavaScript:现代Web开发的核心动力
开发语言·前端·javascript
zhaoyang03011 小时前
vue3笔记(2)自用
前端·javascript·笔记
UrbanJazzerati2 小时前
JavaScript Promise完整指南
javascript
德育处主任Pro2 小时前
# JsSIP 从入门到实战:构建你的第一个 Web 电话
前端
拾光拾趣录2 小时前
setTimeout(1) 和 setTimeout(2) 的区别
前端·v8
拾光拾趣录2 小时前
内存泄漏的“隐形杀手”
前端·性能优化