您现在的位置是:首页 > Javascript
当前栏目
巧技拾遗 | JavaScript 中 Array.every 和 Array.map 的巧妙结合
2023-03-09 22:04:41 时间
这几天在跟着学一点 vue3 + TypeScript 中表单验证的实例,看到一个实现,觉得非常巧妙。
需求概述
我们有一个列表 funcArr ,里面存放函数,比如 funcArr = [ func1, func2, ... ] 。这些函数都是 () => boolean 即无参数、返回值为布尔值的。
我们期望在提交表单时,执行 funcArr 中的每一个函数,如果这些函数都通过验证,则我们的主逻辑获取到 true ,否则是 false 。
朴素版本
- func1 = () => { console.log(1); return true; }
- func2 = () => { console.log(2); return false; }
- func3 = () => { console.log(3); return true; }
- funcArr = [func1, func2, func3];
- result = true;
- for (var i = 0; i < funcArr.length; i ++ )
- {
- if (!funcArr[i]( "i")) result = false;
- }
- console.log(result)
输出是:
- > 1
- > 2
- > 3
- > false
这种做法显然有点瞎扯了,完全没有用到 JavaScript 特性和函数式编程的思想。
Array.prototype.every()
一般来讲,有上述需求,我们用 Array.prototype.every()[1] 函数来解决。
根据 MDN 的描述:every用于检测是否每个函数都通过,并且最终返回 一个 布尔值。
于是:
- func1 = () => { console.log(1); return true; }
- func2 = () => { console.log(2); return false; }
- func3 = () => { console.log(3); return true; }
- funcArr = [func1, func2, func3];
- result = funcArr.every(func => func());
- console.log(result)
输出:
- > 1
- > 2
- > false
可以注意到一个现象:当every发现有一个元素没有通过验证时,它就不再继续检查其他元素了。
结合 map()
有时候,我们的 funcArr 中的函数,不仅仅是单纯的返回一个布尔值,其中还有其他逻辑如修改一些响应式变量的作用。
因此,我们希望 every 能够执行完毕所有函数,即便发现其中某一个是 return false 了的。
考虑使用 map 。
- func1 = () => { console.log(1); return true; }
- func2 = () => { console.log(2); return false; }
- func3 = () => { console.log(3); return true; }
- funcArr = [func1, func2, func3];
- result = funcArr.map(func => func()).every(res => res);
- console.log(result)
输出:
- > 1
- > 2
- > 3
- > false
every在其中的作用,像是一个漏斗,把所有的值依次过滤,有一个 false 就返回 false ,否则是 true 。
相关文章
- 鲜为人知但很有用的 HTML 属性
- 翻转再翻转!有意思的水平横向溢出滚动
- 自定义计数器小技巧!CSS 实现长按点赞累加动画
- 过五关!React高频面试题指南
- 软件开发中的十个认知偏差
- 不需要 JS!仅用 CSS 也能达到监听页面滚动的效果!
- 一文读懂TypeScript类型兼容性
- Vue 的响应式原则与双向数据绑定
- 快速掌握 TypeScript 新语法:Infer Extends
- JWT教你如何证明你是我的人!
- 一篇带给你 V8 GC 的实现
- 面试官:请使用JS完成一个LRU缓存?
- 通过可视化来学习JavaScript事件循环
- 新的跨域策略:使用 COOP、COEP 为浏览器创建更安全的环境
- 为什么有人说 vite 快,有人却说 vite 慢?
- 种草 Vue3 中几个好玩的插件和配置
- 超全面的前端工程化配置指南
- Vue 状态管理未来样子
- Volatile关键字能保证原子性么?
- 面试突击:SpringBoot 有几种读取配置文件的方法?