巧妙地利用apply方法来调用原生的Math.max与Math.min方法迅速求得结果。apply能让一个方法指定调用对象与传入参数, 并且传入参数是以数组形式组织的。恰恰现在有一个方法叫Math.max,调用对象为Math,与多个参数。
Array.max = function( array ) {
return Math.max.apply( Math, array );
};
Array.min = function( array ) {
return Math.min.apply( Math, array );
}
不过,把它们做成Math对象的静态方法,不能使用链式调用了。但这方法还能更精简一些,不要忘记,Math对象也是一个对象,我们用 对象的字面量来写,又可以省几个比特了。
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
方法1:
Array.prototype.max = function() {
return Math.max.apply({},this);
}
Array.prototype.min = function() {
return Math.min.apply({},this);
}
var x = new Array(31, 2322, 355, 88, 5, 6);
var y = x.max();
var index = jQuery.inArray(y, x)
alert(index);
方法2:
function array_max() {
var i, max = this[0];
for (i = 1; i < this.length; i++) {
if (max < this[i]) max = this[i];
}
return max;
}
Array.prototype.max = array_max;
var x = new Array(31, 22, 35, 88, 5, 6);
var y = x.max();
var index = jQuery.inArray(y, x)
alert(index);
方法3:
(function () {
var arr = new Array(1, 7, 346, 44, 32, 10);
Array.prototype.max = function () {
var max = this[0];
var len = this.length;
for (var i = 1; i < len; i++) {
this.index = i;
if (this[i] > max) {
max = this[i];
num = this.index;
}
}
return num;
}
alert(arr.max());
})()