登录
首页 >  文章 >  前端

可迭代 - JavaScript 挑战

来源:dev.to

时间:2024-11-10 09:06:39 296浏览 收藏

偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《可迭代 - JavaScript 挑战》,这篇文章主要会讲到等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!

可迭代 - JavaScript 挑战

您可以在 github 仓库中找到这篇文章中的所有代码。


可迭代相关的挑战


可迭代

/**
 * @param {any} data
 * @return {object}
 */

function createCustomIterable(data) {
  return {
    [Symbol.iterator]() {
      let index = 0;
      return {
        next() {
          if (index < data.length) {
            return {
              value: data[index++],
              done: false,
            };
          } else {
            return {
              value: undefined,
              done: true,
            };
          }
        },
      };
    },
  };
}

// Usage example:
const customIterable = createCustomIterable([1, 2, 3, 4]);

// Using for...of loop
for (const item of customIterable) {
  console.log(item);
}
/**
 * 1
 * 2
 * 3
 * 4
 */

// Using spread operator
const arrayFromIterable = [...customIterable];
console.log(arrayFromIterable); // => [1, 2, 3, 4]

// Using Array.from()
const anotherArray = Array.from(customIterable);
console.log(anotherArray); // => [1, 2, 3, 4]

参考

  • 迭代器 - mdn
  • 迭代协议 - mdn
  • [iterator.prototypesymbol.iterator - mdn](https://developer.mozilla.org/en-us/docs/web/javascript/reference/global_objects/iterator/symbol.iterator)

终于介绍完啦!小伙伴们,这篇关于《可迭代 - JavaScript 挑战》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>