我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

学习目标

  • 分析 arrify 函数的源码
  • 通过测试用例调试源码
  • 学习 Symbol.iterator 的使用场景
  • 其它的可迭代对象

拉取源码

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

项目目录如图:

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

  • index.js是整个项目的入口,负责对外导出arrify函数
  • index.d.tsarrify函数的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 循环来遍历这个数组,循环会自动调用 numbersSymbol.iterator 方法来获取每个元素+1后的值。

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

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

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

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

  • 数组
  • 字符串
  • Map(Map)
  • Set(Set)

总结

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

以上就是arrify 转数组实现示例源码解析的详细内容,更多关于arrify 转数组的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

这篇文章主要为大家介绍了arrify转数组实现示例源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-12-25

JavaScript手写源码之实现arrify转数组

这篇文章主要为大家详细介绍了如何利用JavaScript实现arrify转数组,文中的示例代码讲解详细,对我们学习JavaScript有一点的帮助,需要的可以参考一下
2023-02-09

OpenMPtaskconstruct实现原理及源码示例解析

这篇文章主要为大家介绍了OpenMPtaskconstruct实现原理及源码示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-03-06

c++梅森数源码示例解析

这篇文章主要为大家介绍了c++梅森数源码示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-12-29

Vue3源码分析reactivity实现方法示例

这篇文章主要为大家介绍了Vue3源码分析reactivity实现方法原理示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-28

Vue3源码解析watch函数实例

这篇文章主要为大家介绍了Vue3源码解析watch函数实例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

Qt利用QJson实现解析数组的示例详解

这篇文章主要为大家详细介绍了Qt如何利用QJson实现解析数组功能,文中的示例代码讲解详细,对我们学习Qt有一定帮助,需要的小伙伴可以了解一下
2022-11-13

php数组实现原理的示例分析

这篇文章主要介绍了php数组实现原理的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。php有什么特点1、执行速度快。2、具有很好的开放性和可扩展性。3、PHP支持多种
2023-06-14

c++可变参数模板使用示例源码解析

这篇文章主要为大家介绍了c++可变参数模板使用示例源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-13

flutter优雅实现扫码枪获取数据源示例详解

这篇文章主要为大家介绍了flutter优雅实现扫码枪获取数据源示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-11

java实现二维数组转置的方法示例

本文实例讲述了java实现二维数组转置的方法。分享给大家供大家参考,具体如下:这里在文件中创建Test2、Exchange、Out三个类在Exchange类中编写exchange()方法,在方法中创建两个数组arraryA、arraryB,
2023-05-31

Java数组实现堆排序的示例分析

这篇文章主要为大家展示了“Java数组实现堆排序的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Java数组实现堆排序的示例分析”这篇文章吧。数组全部入堆,再出堆从后向前插入回数组中,数
2023-05-30

PHP转化函数实例解析:日期、字符串、数组转化

PHP是一种广泛应用于Web开发领域的脚本语言,它具有丰富的内置函数,其中转化函数在各种实际项目中都起到了重要作用。本文将重点分析PHP中日期、字符串、数组转化函数的实例解析,并通过具体的代码示例来展示其用法。一、日期转化函数在PHP中
PHP转化函数实例解析:日期、字符串、数组转化
2024-03-07

ReactNative中实现确认码组件示例详解

这篇文章主要为大家介绍了ReactNative中实现确认码组件示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

编程热搜

目录