68-解构赋值,迭代器,生成器函数

1.解构赋值(针对数组array,字符串String及对象object以)

结构赋值是一种特殊的语法,通过将各种结构中的元素复制到变量中达到"解构"的目的,但是数组本身没有改变

1.1解构单层数组

    <script>let arr = [1,2,3,4,5];//获取数组中的第一个元素let ha = arr[0];//获取数组中的每一个元素//将数组arr中的元素一次赋值给变量a,b,c,d,elet [a,b,c,d,e] = arr;console.log(a,b,c,d,e);//输出1 2 3 4 5//取第3个值,数组中不想要的元素可以添加逗号把它丢弃let [a1,,c1] = arr;//等于let [,,c1] = arr;console.log(c1);//输出3</script>

1.2解构多层次的数组

    <script>let array = [[1,2,3],[4,5,6],[7,8,9]];//解构获取数组第3个元素的第2个元素let [,,[,b]] = array;console.log(b);//输出8</script>

1.3解构字符串类型String同上

    <script>let string = 'xyz';let [a,b,c] = string;console.log(a,b,c);//输出x y z[,,c] = string;console.log(c);//输出z</script>

1.4解构赋值对象Object

按对象中的属性名进行解构赋值,修改变量名

    <script>let obj = {name:'张三',age:18,};//按属性名进行解构let {name,age} = obj;console.log(name);//输出张三//修改变量名let {name:aaa,age:bbb} = obj;console.log(bbb);//输出18//aaa,bbb是重新声明的变量名称</script>

对已经存在的变量进行解构赋值

    <script>let obj = {name:'张三',age:18,};let name,age;//{name,age} = obj;//报错,语句被解析为对代码块进行赋值,代码块不允许被赋值({name,age} = obj);//解决办法加一个()console.log(name,age);//输出 张三 18</script>

默认值属性值为undefined时默认值生效

    <script>let obj = {name:'张三',age:18,};let {name,age,_sex:sex='男'} = obj;console.log(name,age,sex);//输出 张三 18 男let abc = {name1:'李四',age1:'19',_sex1:'女',}let {name1,age1,_sex1:sex2='男'} = abcconsole.log(name1,age1,sex2);//输出 李四 19 女//默认值被覆盖</script>

嵌套解构赋值

    <script>let obj = {name:'张三',age:18,hobby:['足球'],//hobby是数组用[],作用是定位};let {name,hobby:[a]} = obj;console.log(name,a);//输出张三 足球</script>

2.迭代器

迭代器对象是由 可迭代协议([Symbol.iterator]方法) 和 迭代器协议(next方法) 构成

迭代器是一个对象,定义一个序列,并在终止时可能附带一个返回值;

2.1枚举for-in,会无序遍历对象里面的属性(没有办法自定义循环过程)

  <body><script>let obj = {name:'zhangsan',age:19,};for(let index in obj){//index代表索引和属性console.log(index,obj[index]);//index代表所有属性名,obj[index]代表所有属性值}</script>

2.2可迭代协议

有一个[Symbol.iterator]方法,需要返回一个迭代器对象,具有唯一性

2.3迭代器协议

迭代器通过使用 next() 方法实现了迭代器协议的任何一个对象,该方法返回具有两个属性对象

value:迭代的值;

done:是否迭代完完成;(ture迭代完成)(false迭代完成)

2.4迭代for-of,自定义遍历过程 

    <script>let obj = {//obj是一个迭代器对象,因为里面拥有一个next方法并且返回了一个值name: "zhangsan",age: 19,count: 5,//可迭代协议 条件1[Symbol.iterator]: function () {  return this;//返回迭代器对象 条件2},//迭代器协议 条件1next() {if (this.count > 0) {return { value: this.count--, done: false };//迭代器协议 条件2}else{return{value:0,done:true};}},};//迭代for (let item of obj) {console.log(item);//输出5 4 3 2 1//item拿到的是if里面value的值}</script>

3.生成器函数

生成器对象(generator)是由一个generator function返回的,它同时符合可迭代协议和迭代器协议

 生成器函数是一种特殊类型的函数,它返回一个生成器对象,这个对象可以用来实现可迭代对象。它可以使用特殊的语法来控制生成器对象的输出,实现按需生成值序列,避免一次性生成大量的值,减少了内存的使用(都是为了构建可迭代对象,自定义迭代过程)

3.1生成器函数定义使用function*关键字,语法如下:

function* generator() {// 函数体
}
    <script>function*  generator(){console.log('run1');//return默认返回undefined}//调用生成器函数,返回生成器对象,--此时生成器函数的代码块并不执行let g = generator();//g是一个生成器对象console.log(g);g.next();//调用生成器函数当中的next()方法//此时生成器函数当中的代码块开始执行let r = g.next();console.log(r);//输出结果如下</script>

 3.2yield关键字,暂停代码执行,并将后面的值返回

function* generateSequence() {yield 1;yield 2;yield 3;
}const generator = generateSequence();console.log(generator.next().value); // 1
console.log(generator.next().value); // 2
console.log(generator.next().value); // 3

3.3结束迭代.return()

    <script>function*  generator(){yield 1;yield 2;yield 3;}let g = generator();let r1 = g.next();g.return();let r2 = g.next();let r3 = g.next();console.log(r1,r2,r3);//{value: 1, done: false}//{value: undefined, done: true}//{value: undefined, done: true}</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/716587.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c++ primer学习笔记(一)

目录 第一章、c快速入门 重点&#xff1a;类的简介 第二章 1、基本内置类型 2、字面值常量 1、整型字面值规则 2、浮点字面值规则 3、布尔字面值 4、字符字面值 5、非打印字符的转义序列 ​编辑 6、字符串字面值 3、变量 1、变量标识符 2、定义和初始化对象 3、…

java: 无法访问org.springframework.web.bind.annotation.RequestMapping......类文件具有错误的版本 61.0, 应为 52.0

文章目录 一、报错问题二、问题背景三、原因分析四、解决方案 一、报错问题 java: 无法访问org.springframework.web.bind.annotation.RequestMapping 错误的类文件: /D:/SoftwareInstall/Maven/repository/org/springframework/spring-web/6.0.9/spring-web-6.0.9.jar!/org/s…

latex报错Repeated entry解决办法

报错原因——重复了两个参考文献&#xff0c;删掉一个即可 总结 "Repeated entry"这个错误通常出现在你尝试在LaTeX中多次使用同一个标签&#xff08;label&#xff09;或者多次插入相同的图像/表格等时。例如&#xff0c;在LaTeX中&#xff0c;我们可能会为每一个章…

Modern C++ std::any为何要求Tp可拷贝构造?

小问题也会影响设计的思路&#xff0c;某个问题或某种case的探讨有助于理解设计的初衷。 声明&#xff1a;以下_Tp/Tp都是指要放入std::any的对象的类型。 它要求_Tp is_copy_constructible, 仅仅是因为有很多函数的实现调用了Tp的拷贝构造函数吗&#xff1f;比如说上节提到的初…

动态SQL的处理

学习视频&#xff1a;3001 动态SQL中的元素_哔哩哔哩_bilibili 目录 1.1为什么学 1.2动态SQL中的元素 条件查询操作 if 元素 choose、when、otherwise元素 where、trim元素 更新操作 set元素使用场景 复杂查询操作 foreach 元素中的属性 ​编辑 迭代数组 迭代List 迭代Map 1…

第3部分 原理篇2去中心化数字身份标识符(DID)(4)

3.2.3. DID解析 3.2.3.1. DID解析参与方 图3-5 DID 解析过程 本聪老师&#xff1a;我们之前提到过&#xff0c;DID 解析过程是将 DID 转换为对应的 DID 文档。这样做的目的是验证 DID 所代表的主体的身份。那么解析过程会涉及哪些概念呢&#xff1f;我们看图3-&#xff0c;DI…

端智能:面向手机计算环境的端云协同AI技术创新

近年来&#xff0c;随着移动端设备软硬件能力的进步&#xff0c;移动端的算力有了很大提升&#xff0c;同时面向移动端的机器学习框架和模型轻量化技术越来越成熟&#xff0c;端上的AI能力逐渐进入大众视野&#xff0c;端智能在电商领域也开始逐步走向规模化应用。通过持续探索…

leetcode日记(35)跳跃游戏Ⅱ

想了一个晚上&#xff0c;第一个思路是用动态规划&#xff0c;记录走到每一个节点需要跳动的最小步数&#xff0c;大致方法是每走到一个节点就遍历一下前面的全部节点&#xff0c;看看哪个节点可以一部跳到该节点&#xff0c;然后从中选取跳跃步数最小的节点&#xff0c;最后输…

基于springboot+vue的城镇保障性住房管理系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

练习 3 Web [ACTF2020 新生赛]Upload

[ACTF2020 新生赛]Upload1 中间有上传文件的地方&#xff0c;试一下一句话木马 txt 不让传txt 另存为tlyjpg&#xff0c;木马文件上传成功 给出了存放目录&#xff1a; Upload Success! Look here~ ./uplo4d/06a9d80f64fded1e542a95e6d530c70a.jpg 下一步尝试改木马文件后缀…

从头构建gpt2 基于Transformer

从头构建gpt2 基于Transformer VX关注{晓理紫|小李子}&#xff0c;获取技术推送信息&#xff0c;如感兴趣&#xff0c;请转发给有需要的同学&#xff0c;谢谢支持&#xff01;&#xff01; 如果你感觉对你有所帮助&#xff0c;请关注我。 源码获取 VX关注晓理紫并回复“chatgpt…

CSS 自测题

盒模型的宽度计算 默认为标准盒模型 box-sizing:content-box; offsetWidth (内容宽度内边距 边框)&#xff0c;无外边距 答案 122px通过 box-sizing: border-box; 可切换为 IE盒模型 offsetWidth width 即 100px margin 纵向重叠 相邻元素的 margin-top 和 margin-bottom 会发…

Benchmark学习笔记

小记一篇Benchmark的学习笔记 1.什么是benchmark 在维基百科中&#xff0c;是这样子讲的 “As computer architecture advanced, it became more difficult to compare the performance of various computer systems simply by looking at their specifications.Therefore, te…

python标识符、变量和常量

一、保留字与标识符 1.1保留字 保留字是指python中被赋予特定意义的单词&#xff0c;在开发程序时&#xff0c;不可以把这些保留字作为变量、函数、类、模块和其它对象的名称来使用。 比如&#xff1a;and、as、def、if、import、class、finally、with等 查询这些关键字的方…

【LeetCode】升级打怪之路 Day 11 加餐:单调队列

今日题目&#xff1a; 239. 滑动窗口最大值 | LeetCode 今天学习了单调队列这种特殊的数据结构&#xff0c;思路很新颖&#xff0c;值得学习。 Problem&#xff1a;单调队列 【必会】 与单调栈类似&#xff0c;单调队列也是一种特殊的数据结构&#xff0c;它相比与普通的 que…

【NR 定位】3GPP NR Positioning 5G定位标准解读(一)

目录 前言 1. 3GPP规划下的5G技术演进 2. 5G NR定位技术的发展 2.1 Rel-16首次对基于5G的定位技术进行标准化 2.2 Rel-17进一步提升5G定位技术的性能 3. Rel-18 关于5G定位技术的新方向、新进展 3.1 Sidelink高精度定位功能 3.2 针对上述不同用例&#xff0c;3GPP考虑按…

Go-知识简短变量声明

Go-知识简短变量声明 1. 简短变量声明符2. 简短变量赋值可能会重新声明3. 简短变量赋值不能用于函数外部4. 简短变量赋值作用域问题5. 总结 githuio地址&#xff1a;https://a18792721831.github.io/ 1. 简短变量声明符 在Go语言中&#xff0c;可以使用关键字var或直接使用简短…

【STK】手把手教你利用STK进行仿真-STK软件基础02 STK系统的软件界面01 STK的界面窗口组成

STK系统是Windows窗口类型的桌面应用软件,功能非常强大。在一个桌面应用软件中集成了仿真对象管理、仿真对象属性参数、设置、空间场景二三维可视化、场景显示控制欲操作、仿真结果报表定制与分析、对象数据管理、仿真过程控制、外部接口连接和系统集成编程等复杂的功能。 STK…

SpringBoot之Actuator的两种监控模式

SpringBoot之Actuator的两种监控模式 springboot提供了很多的检测端点(Endpoint),但是默认值开启了shutdown的Endpoint&#xff0c;其他默认都是关闭的,可根据需要自行开启 文章目录 SpringBoot之Actuator的两种监控模式1. pom.xml2. 监控模式1. HTTP2. JMX 1. pom.xml <de…

力扣 第 125 场双周赛 解题报告 | 珂学家 | 树形DP + 组合数学

前言 整体评价 T4感觉有简单的方法&#xff0c;无奈树形DP一条路上走到黑了&#xff0c;这场还是有难度的。 T1. 超过阈值的最少操作数 I 思路: 模拟 class Solution {public int minOperations(int[] nums, int k) {return (int)Arrays.stream(nums).filter(x -> x <…