JavaScript 专题之如何求数组的最大值和最小值
前言
取出数组中的最大值或者最小值是开发中常见的需求,但你能想出几种方法来实现这个需求呢?
Math.max
JavaScript 提供了 Math.max 函数返回一组数中的最大值,用法是:
1 | Math.max([value1[,value2, ...]]) |
值得注意的是:
- 如果有任一参数不能被转换为数值,则结果为 NaN。
- max 是 Math 的静态方法,所以应该像这样使用:Math.max(),而不是作为 Math 实例的方法 (简单的来说,就是不使用 new )
- 如果没有参数,则结果为
-Infinity
(注意是负无穷大)
而我们需要分析的是:
1.如果任一参数不能被转换为数值,这就意味着如果参数可以被转换成数字,就是可以进行比较的,比如:
1 | Math.max(true, 0); // 1 |
2.如果没有参数,则结果为 -Infinity,对应的,Math.min 函数,如果没有参数,则结果为 Infinity,所以:
1 | var min = Math.min(); |
了解了 Math.max 方法,我们以求数组最大值的为例,思考有哪些方法可以实现这个需求。
原始方法
最最原始的方法,莫过于循环遍历一遍:
1 | var arr = [6, 4, 1, 8, 2, 11, 23]; |
reduce
既然是通过遍历数组求出一个最终值,那么我们就可以使用 reduce 方法:
1 | var arr = [6, 4, 1, 8, 2, 11, 23]; |
排序
如果我们先对数组进行一次排序,那么最大值就是最后一个值:
1 | var arr = [6, 4, 1, 8, 2, 11, 23]; |
eval
Math.max 支持传多个参数来进行比较,那么我们如何将一个数组转换成参数传进 Math.max 函数呢?eval 便是一种
1 | var arr = [6, 4, 1, 8, 2, 11, 23]; |
apply
使用 apply 是另一种。
1 | var arr = [6, 4, 1, 8, 2, 11, 23]; |
ES6 …
使用 ES6 的扩展运算符:
1 | var arr = [6, 4, 1, 8, 2, 11, 23]; |
有更多的方法欢迎留言哈~
专题系列
JavaScript 专题系列目录地址:https://github.com/mqyqingfeng/Blog。
JavaScript 专题系列预计写二十篇左右,主要研究日常开发中一些功能点的实现,比如防抖、节流、去重、类型判断、拷贝、最值、扁平、柯里、递归、乱序、排序等,特点是研(chao)究(xi) underscore 和 jQuery 的实现方式。
如果有错误或者不严谨的地方,请务必给予指正,十分感谢。如果喜欢或者有所启发,欢迎 star,对作者也是一种鼓励。