//最小值 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; } console.log([55,38,7,19].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; } console.log([55,38,7,19].max());
运行结果:
如果引用了别的类库进行开发,害怕类库也用了同名的原型方法,可以在生成函数之前可以进行重名判断:
if(typeof Array.prototype['max'] == 'undefined'){ Array.prototype.max = function(){...} }
方法二:
//最小值 Math.min.apply(Math,arr); //等效于 Math.min.apply({},arr)和Math.min.apply(null,arr); //原本取得最小值的方法是Math.min(n1,n2,n3...), apply可以改变参数的传入形式,第一个参数是什么都不是很重要 //最大值 var arr = [55,38,7,19]; console.log(Math.max.apply(Math,arr));
运行结果:
多维数组可以先打散为一维数组再做以上处理。
var arr1 = [1,2,3,[5,6],[3,4,8]]; var arr2 = arr1.join(",").split(","); var a = Math.min.apply(Math,arr2); console.log(a);
运行结果:
方法三:
var arr = [55,38,7,19]; function getMaxMin(arr,maxmin){ if(maxmin === "max"){ return Math.max.apply(Math,arr); }else if(maxmin === "min"){ return Math.min.apply(Math,arr); } } var a = getMaxMin(arr,"max"); console.log(a); var b = getMaxMin(arr,"min"); console.log(b);
运行结果:
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:测试上述代码运行效果。
更多关于JavaScript相关内容还可查看本站专题:《JavaScript数组操作技巧总结》、《JavaScript字符与字符串操作技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript错误与调试技巧总结》