首页 >> js开发 >> jsJavascript中Math.max和Math.max.apply的区别和用法详解js大全
jsJavascript中Math.max和Math.max.apply的区别和用法详解js大全
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
最近在做一个小案例的时候遇到了Math.max.apply这么一个用法,之前很少遇到过感觉挺有趣的,就记录一下。1Math.max1Math.max1Math.max语法: Math.max(n1,n2,n3,...,nX)
返回值:max() 方法可返回指定的参数中带有较大的值的那个数Math.max(n1,n2,n3,...,nX)
var a = Math.max(1,2,3,4);
console.log(a); //4
var a = Math.max(1,2,3,4);
console.log(a); //4但是如果数据是放在一个数组里面,此时就不能这样调用了。这时就用到apply方法2Math.max.apply2Math.max.apply2Math.max.applyapply() 方法调用一个函数。简单理解为调用函数的方式,但是它可以改变函数的 this 指向,同时用指定数组替换函数的参数。语法:fun.apply(thisArg, [argsArray]) fun.apply(thisArg, [argsArray])
thisArg:在fun函数运行时指定的 this 值 ,可以为null,就是不设置指向
argsArray:传递的值,必须包含在数组里面
thisArg:在fun函数运行时指定的 this 值 ,可以为null,就是不设置指向argsArray:传递的值,必须包含在数组里面这里额外补充一下,传递的值为数组形式,但是数组里是什么类型参数,返回的也是什么类型,比如输入的数组中是字符串这里取到的就是字符串,是数值取到的就是数值。比如传‘abc' 返回的也是‘abc'。(补充说明)返回值:apply() 方法的返回值就是函数的返回值,因为它就是调用函数
var arr = [1, 66, 3, 99, 4];
var max = Math.max.apply(Math, arr);
var min = Math.min.apply(Math, arr);
console.log(max); //99
console.log(min); //1
var arr = [1, 66, 3, 99, 4];
var max = Math.max.apply(Math, arr);
var min = Math.min.apply(Math, arr);
console.log(max); //99
console.log(min); //12.1Math.max.apply拓展案例2.1Math.max.apply拓展案例这里我再举一个应用案例———自动生成编号(自增)
说明:data为一个json数组,里面的每个对象都一个id值
let maxBookCode = ()=>{
let arr = [];
//遍历json数组,把所有对象的id存到arr这个空数组当中
data.forEach((item)=>{
arr.push(item.id);
});
//最后返回里面id值最大的那个数
return Math.max.apply(null,arr);
}
let maxBookCode = ()=>{
let arr = [];
//遍历json数组,把所有对象的id存到arr这个空数组当中
data.forEach((item)=>{
arr.push(item.id);
});
//最后返回里面id值最大的那个数
return Math.max.apply(null,arr);
}外部调用 maxBookCode() + 1 就能自动生成编号并且是自增的。总结总结总结
返回值:max() 方法可返回指定的参数中带有较大的值的那个数Math.max(n1,n2,n3,...,nX)
var a = Math.max(1,2,3,4);
console.log(a); //4
var a = Math.max(1,2,3,4);
console.log(a); //4但是如果数据是放在一个数组里面,此时就不能这样调用了。这时就用到apply方法2Math.max.apply2Math.max.apply2Math.max.applyapply() 方法调用一个函数。简单理解为调用函数的方式,但是它可以改变函数的 this 指向,同时用指定数组替换函数的参数。语法:fun.apply(thisArg, [argsArray]) fun.apply(thisArg, [argsArray])
thisArg:在fun函数运行时指定的 this 值 ,可以为null,就是不设置指向
argsArray:传递的值,必须包含在数组里面
thisArg:在fun函数运行时指定的 this 值 ,可以为null,就是不设置指向argsArray:传递的值,必须包含在数组里面这里额外补充一下,传递的值为数组形式,但是数组里是什么类型参数,返回的也是什么类型,比如输入的数组中是字符串这里取到的就是字符串,是数值取到的就是数值。比如传‘abc' 返回的也是‘abc'。(补充说明)返回值:apply() 方法的返回值就是函数的返回值,因为它就是调用函数
var arr = [1, 66, 3, 99, 4];
var max = Math.max.apply(Math, arr);
var min = Math.min.apply(Math, arr);
console.log(max); //99
console.log(min); //1
var arr = [1, 66, 3, 99, 4];
var max = Math.max.apply(Math, arr);
var min = Math.min.apply(Math, arr);
console.log(max); //99
console.log(min); //12.1Math.max.apply拓展案例2.1Math.max.apply拓展案例这里我再举一个应用案例———自动生成编号(自增)
说明:data为一个json数组,里面的每个对象都一个id值
let maxBookCode = ()=>{
let arr = [];
//遍历json数组,把所有对象的id存到arr这个空数组当中
data.forEach((item)=>{
arr.push(item.id);
});
//最后返回里面id值最大的那个数
return Math.max.apply(null,arr);
}
let maxBookCode = ()=>{
let arr = [];
//遍历json数组,把所有对象的id存到arr这个空数组当中
data.forEach((item)=>{
arr.push(item.id);
});
//最后返回里面id值最大的那个数
return Math.max.apply(null,arr);
}外部调用 maxBookCode() + 1 就能自动生成编号并且是自增的。总结总结总结
相关文章:
- js全网小程序接口请求封装实例代码js大全
- jsOpenlayers+EasyUI Tree动态实现图层控制js大全
- js微信小程序自定义tabBar的踩坑实践记录js大全
- JavaScript工作中常用js功能汇总
- jsnuxt 路由、过渡特效、中间件的实现代码js大全
- js微信小程序中target和currentTarget的区别小结js大全
- jsnuxt静态部署打包相对路径操作js大全
- js解决nuxt页面中mounted、created、watch执行两遍的问题js大全
- js解决VUE 在IE下出现ReferenceError: Promise未定义的问题js大全
- JavaScriptNuxt.js的路由跳转操作(页面跳转nuxt-link)