摘要:问题一求一个函数可以实现以下功能函数入参一个数组,数组元素只能为三种或者期望返回值或者,满足数组元素只要有一个,返回数组元素全为,返回数组元素非的全部为,返回例如满足,期望返回值满足,期望返回值满足,期望返回值满足,期望返回值问题二求一个函
问题一、 求一个JS函数可以实现以下功能:
函数入参:一个数组,数组元素只能为三种:{flag: true}、{flag: false} 或者""
期望返回值:true或者false,满足:
1.数组元素只要有一个{flag: false},返回false
2.数组元素全为"",返回false
3.数组元素非""的全部为{flag: true},返回true
例如
const array1 = [{flag: true}, {flag: false}, ""; // 满足1,期望返回值false const array2 = ["", "", "", "", "", ""]; // 满足2,期望返回值false const array3 = [{flag: true}, {flag: true}, ""]; // 满足3,期望返回值true const array4 = [{flag: true}, {flag: true}, {flag: true}]; // 满足3,期望返回值true问题二 求一个JS函数可以实现以下功能:
函数入参:一个数组(以下称为入参数组),数组元素只能为三种:{flag: true}、{flag: false} 或者""
期望返回值:一个length为2的数组(以下称为结果数组). 满足
1.结果数组的第一个元素为入参数组index为0、2、4、6等非奇数位元素组合符合问题一的返回值
1.结果数组的第二个元素为入参数组index为1、3、5、7等奇数为元素组合符合问题一的返回值
例如
const array1 = [{flag: true}, {flag: true}, {flag: true}, "", {flag: false}]; 非奇数位(index等于0,2,4)组合 [{flag: true}, {flag: true}, {flag: false}] // 根据问题一描述,结果false 奇数位为(index等于1,3)组合 [{flag: true}, ""] // 根据问题一描述,结果为true 期望返回值[false, true]示例代码 问题一:
function func (array) { let result = ""; array.forEach((item) => { if (item !== "") { if (result === "") { result = item.flag; } else { result = result && item.flag; } } }) return !!result; }问题二:
function func2 (array) { let result = ["", ""]; array.forEach((item, index) => { if (item !== "") { if (result[index % 2] === "") { result[index % 2] = item.flag; } else { result[index % 2] = result[index % 2] && item.flag; } } }); result.forEach(item => { item = item && true; }) return result; }
感觉自己写的过程太麻烦了,有没有更简单的写法呢
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/89983.html
摘要:看完视频初步认识了一下,以及模块化开发的概念,在此做一下总结。所以应该将功能抽象成模块。并且非常耗性能解决办法,在滚动条正在运动或者已经到达目的地,就不应该执行动画。 前言:在慕课网上跟着视频《侧边工具栏开发》做了一遍,用到了jquery操作DOM,其中,用requirejs管理模块依赖,然后自定义了两个模块它们都依赖jquery,并且其中一个自定义模块依赖另一个,所以要暴露出接口。看...
摘要:回调函数是在异步操作完成后传播其操作结果的函数,总是用来替代同步操作的返回指令。下面的图片显示了中事件循环过程当异步操作完成时,执行权就会交给这个异步操作开始的地方,即回调函数。 本系列文章为《Node.js Design Patterns Second Edition》的原文翻译和读书笔记,在GitHub连载更新,同步翻译版链接。 欢迎关注我的专栏,之后的博文将在专栏同步: Enc...
摘要:是在收到响应后执行的函数,可以不用返回。一步步介绍了如何构建以及使用中间层,来统一管理接口地址,最后还介绍了下中间件等高级功能。 零、问题的由来 开门见山地说,这篇文章是一篇安利软文~,安利的对象就是最近搞的 tua-api。 顾名思义,这就是一款辅助获取接口数据的工具。 发请求相关的工具辣么多,那我为啥要用你呢? 理想状态下,项目中应该有一个 api 中间层。各种接口在这里定义,业务...
阅读 1989·2021-11-11 16:54
阅读 1007·2021-10-12 10:12
阅读 348·2019-08-30 15:43
阅读 596·2019-08-29 13:15
阅读 1040·2019-08-29 13:12
阅读 1477·2019-08-26 12:09
阅读 1623·2019-08-26 10:24
阅读 2183·2019-08-26 10:15