html查找一维数组中的最小值,[前端]原生js获取数组中的最大值max和最小值min的方法总结...

原生jJavaScript获取数组中的最大值和最小值:方法一:传统循环遍历,方法二:利用Math.max和Math.min,方式三.利用sort排序...

方法一:传统循环遍历//最小值

Array.prototype.min = function() {

var min = this[0];

var len = this.length;

for(var i = 1; i < len; i++) {

if(this[i] < min) {

min = this[i];

}

}

return min;

}

//最大值

Array.prototype.max = function() {

var max = this[0];

var len = this.length;

for(var i = 1; i < len; i++) {

if(this[i] > max) {

max = this[i];

}

}

return max;

}

var numbers = [10, 500 , 0 , -15 ];

console.log(numbers.max());//500

console.log(numbers.min());//-15

方法二:利用Math.max和Math.min

1.利用apply-一维数组var numbers = [10, 500 , 0 , -15 ];

console.log(Math.min.apply(null, numbers));//-15

console.log(Math.max.apply(null, numbers));//200

2.apply集成到Array.min和Array.max:Array.max = function(array){

return Math.max.apply(Math,array );

};

Array.min = function( array ){

return Math.min.apply(Math,array );

};

3.apply使用链式Array.prototype.max = function(){

return Math.max.apply({},this)

}

Array.prototype.min = function(){

return Math.min.apply({},this)

}

[1,2,3].max()// => 3

[1,2,3].min()// => 1

4.使用ES6var numbers = [10, 500 , 0 , -15 ];

console.log(Math.min(...numbers));//-15

console.log(Math.max(...numbers));//200

5.利用evalvar numbers = [10, 500 , 0 , -15 ];

var max = eval("Math.max(" + numbers + ")");

console.log(max)//500

var min = eval("Math.min(" + numbers + ")");

console.log(min)//-15

6.利用apply-多维数组var numbers=[10,500,[-15,0],[1,2,3]];

var n=numbers.join(",").split(",");//转化为一维数组

console.log(Math.max.apply(null,n));//最大值500

console.log(Math.min.apply(null,n));//最小值-15

方式三.利用sort排序:var numbers = [10, 500 , 0 , -15 ];

numbers.sort(function(a,b){return a - b;});

console.log(numbers[numbers.length - 1]);//最大值500

console.log(numbers[0]);//最小值-15

我们先对数组进行一次从大到小的排序,那么最大值就是最后一个值,最小值就是第一个了。

总结:

除了上面方法外,还有其他的实现方式!请留言哦~~~

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值