遍历 - 带计数器的`each()`函数
创始人
2024-12-02 02:31:49
0

在JavaScript中,我们可以自定义一个带计数器的each()函数来遍历数组或对象。下面是一个示例代码:

function each(collection, callback) {
  if (Array.isArray(collection)) {
    for (let i = 0; i < collection.length; i++) {
      callback(collection[i], i);
    }
  } else {
    for (let key in collection) {
      callback(collection[key], key);
    }
  }
}

// 示例用法
const arr = ['a', 'b', 'c'];
each(arr, (value, index) => {
  console.log(`Index ${index}: ${value}`);
});

const obj = { foo: 'bar', baz: 'qux' };
each(obj, (value, key) => {
  console.log(`Key ${key}: ${value}`);
});

在上面的代码中,我们定义了一个名为each()的函数,它接受两个参数:collectioncallbackcollection可以是数组或对象,callback是一个函数,它将被应用于每个集合中的元素。

在函数内部,我们首先检查collection的类型。如果是数组,我们使用for循环遍历每个元素,并将元素和索引作为参数传递给callback函数。如果是对象,我们使用for...in循环遍历每个键值对,并将值和键作为参数传递给callback函数。

在示例用法中,我们分别使用了一个数组和一个对象来演示each()函数的工作方式。在每个回调函数中,我们打印出了每个元素或键值对的索引或键以及对应的值。

运行上面的代码将输出以下结果:

Index 0: a
Index 1: b
Index 2: c
Key foo: bar
Key baz: qux

这表明each()函数成功地遍历了数组和对象,并在每个元素或键值对上执行了指定的操作。

相关内容

热门资讯

安卓换鸿蒙系统会卡吗,体验流畅... 最近手机圈可是热闹非凡呢!不少安卓用户都在议论纷纷,说鸿蒙系统要来啦!那么,安卓手机换上鸿蒙系统后,...
安卓系统拦截短信在哪,安卓系统... 你是不是也遇到了这种情况:手机里突然冒出了很多垃圾短信,烦不胜烦?别急,今天就来教你怎么在安卓系统里...
app安卓系统登录不了,解锁登... 最近是不是你也遇到了这样的烦恼:手机里那个心爱的APP,突然就登录不上了?别急,让我来帮你一步步排查...
安卓系统要维护多久,安卓系统维... 你有没有想过,你的安卓手机里那个陪伴你度过了无数日夜的安卓系统,它究竟要陪伴你多久呢?这个问题,估计...
windows官网系统多少钱 Windows官网系统价格一览:了解正版Windows的购买成本Windows 11官方价格解析微软...
安卓系统如何卸载app,轻松掌... 手机里的App越来越多,是不是感觉内存不够用了?别急,今天就来教你怎么轻松卸载安卓系统里的App,让...
怎么复制照片安卓系统,操作步骤... 亲爱的手机控们,是不是有时候想把自己的手机照片分享给朋友,或者备份到电脑上呢?别急,今天就来教你怎么...
安卓系统应用怎么重装,安卓应用... 手机里的安卓应用突然罢工了,是不是让你头疼不已?别急,今天就来手把手教你如何重装安卓系统应用,让你的...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
安装了Anaconda之后找不... 在安装Anaconda后,如果找不到Jupyter Notebook,可以尝试以下解决方法:检查环境...