阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

解析arrify 转数组实现示例源码

107次阅读
没有评论

共计 1499 个字符,预计需要花费 4 分钟才能阅读完成。

导读 这篇文章主要为大家介绍了 arrify 转数组实现示例源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
学习目标
  • 分析 arrify 函数的源码
  • 通过测试用例调试源码
  • 学习 Symbol.iterator 的使用场景
  • 其它的可迭代对象
  • 拉取源码

    进入到 arrify 仓库下,使用 CodeSpace 克隆一份项目。

    项目目录如图:

    解析 arrify 转数组实现示例源码

    忽略掉一些配置文件,各个文件的功能如下:

  • index.js 是整个项目的入口,负责对外导出 arrify 函数
  • index.d.ts 是 arrify 函数的 TS 类型描述文件
  • test.js 是测试用例
  • 分析源码

    arrify 函数可以接受一个值,并返回一个包含该值的数组, 根据传入不同类型的值返回不同的结果。

    export default function arrify(value) {
            // 如果传入的值是 null 或 undefined,函数会返回一个空数组。if (value === null || value === undefined) {return [];
        }
            // 如果传入的值本身就是一个数组,函数会直接返回这个数组
        if (Array.isArray(value)) {return value;}
            // 如果传入的值是一个字符串,函数会返回一个包含该字符串的数组。if (typeof value === 'string') {return [value];
        }
            // 如果传入的值是一个可迭代对象,函数会返回一个包含该对象所有元素的数组。if (typeof value[Symbol.iterator] === 'function') {return [...value];
        }
            // 如果传入的值既不是 null/undefined,也不是一个数组 / 字符串 / 可迭代对象,函数会返回一个包含该值的数组。return [value];
    }
    Symbol.iterator 的使用场景

    Symbol.iterator 是 JavaScript 中的一个内置 Symbol,它用于定义一个对象的默认迭代器。当一个对象被用于 for…of 循环或者解构赋值时,会自动调用它的 Symbol.iterator 方法。

    举个例子,假设你有一个数组,你可以使用 Symbol.iterator 方法来定义如何遍历这个数组:

    const numbers = [1, 2, 3];
    numbers[Symbol.iterator] = function() {
      let i = 0;
      return {next: function() {
          return {value: numbers[i] + 1,
            done: i++ === numbers.length
          };
        }
      };
    };
    for (const num of numbers) {console.log(num);
    }

    上面的代码定义了一个数组 numbers,并为它定义了一个 Symbol.iterator 方法,这个方法返回一个迭代器对象,这个对象的 next 方法返回数组的下一个元素。然后我们使用 for…of 循环来遍历这个数组,循环会自动调用 numbers 的 Symbol.iterator 方法来获取每个元素 + 1 后的值。

    上面代码执行的执行结果:

    解析 arrify 转数组实现示例源码

    可见我们更改了 array 的默认迭代器。

    具有默认的迭代器函数的对象

    这些对象能够被 for…of 循环遍历

  • 数组
  • 字符串
  • Map(Map)
  • Set(Set)
  • 总之,一个数据结构如果具有 Symbol.iterator 属性,这个对象就可以被 for…of 遍历它的成员。我们理解 iteration 的原理可以更好使用 js 提供的数据结构,必要时还可以改造不可迭代的数据结构。

    阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

    腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

    代金券:在阿里云专用满减优惠券

    正文完
    星哥玩云-微信公众号
    post-qrcode
     0
    星锅
    版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计1499字。
    转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
    【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
    阿里云-最新活动爆款每日限量供应
    评论(没有评论)
    验证码
    【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中