Javascript中Math.max和Math.max.apply的区别和用法详解


Posted in Javascript onAugust 24, 2020

最近在做一个小案例的时候遇到了Math.max.apply这么一个用法,之前很少遇到过感觉挺有趣的,就记录一下。

1Math.max

语法: Math.max(n1,n2,n3,...,nX)
返回值:max() 方法可返回指定的参数中带有较大的值的那个数

var a = Math.max(1,2,3,4);
console.log(a); //4

但是如果数据是放在一个数组里面,此时就不能这样调用了。这时就用到apply方法

2Math.max.apply

apply() 方法调用一个函数。简单理解为调用函数的方式,但是它可以改变函数的 this 指向,同时用指定数组替换函数的参数。

语法:fun.apply(thisArg, [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

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);
}

外部调用 maxBookCode() + 1 就能自动生成编号并且是自增的。

总结

到此这篇关于Javascript中Math.max和Math.max.apply的区别和用法的文章就介绍到这了,更多相关Javascript中Math.max和Math.max.apply的区别和用法内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
JS中Date日期函数中的参数使用介绍
Jan 02 Javascript
javascript实现的字符串与十六进制表示字符串相互转换方法
Jul 17 Javascript
JS实现横向与竖向两个选项卡Tab联动的方法
Sep 27 Javascript
JavaScript实现in-place思想的快速排序方法
Aug 07 Javascript
关于angularJs指令的Scope(作用域)介绍
Oct 25 Javascript
微信小程序开发之animation循环动画实现的让云朵飘效果
Jul 14 Javascript
webpack+vue中使用别名路径引用静态图片地址
Nov 20 Javascript
详解Vue实战指南之依赖注入(provide/inject)
Nov 13 Javascript
vue 对象添加或删除成员时无法实时更新的解决方法
May 01 Javascript
小程序实现简单语音聊天的示例代码
Jul 24 Javascript
jquery插件懒加载的示例
Oct 24 jQuery
javaScript Array api梳理
Mar 31 Javascript
在Vue中使用HOC模式的实现
Aug 23 #Javascript
详解Howler.js Web音频播放终极解决方案
Aug 23 #Javascript
利用React高阶组件实现一个面包屑导航的示例
Aug 23 #Javascript
vue中watch和computed的区别与使用方法
Aug 23 #Javascript
vue动态设置页面title的方法实例
Aug 23 #Javascript
Vue管理系统前端之组件拆分封装详解
Aug 23 #Javascript
Vue中keep-alive组件的深入理解
Aug 23 #Javascript
You might like
详解WordPress中创建和添加过滤器的相关PHP函数
2015/12/29 PHP
php微信开发之带参数二维码的使用
2016/08/03 PHP
PHP实现的简单异常处理类示例
2017/05/04 PHP
laravel 使用事件系统统计浏览量的实现
2019/10/16 PHP
jquery批量控制form禁用的代码
2013/08/06 Javascript
js中精确计算加法和减法示例
2014/03/28 Javascript
JS简单计算器实例
2015/01/20 Javascript
JS+CSS实现自动改变切换方向图片幻灯切换效果的方法
2015/03/02 Javascript
探讨JavaScript语句的执行过程
2016/01/28 Javascript
jQuery插件ImageDrawer.js实现动态绘制图片动画(附源码下载)
2016/02/25 Javascript
Vue.js中用v-bind绑定class的注意事项
2016/12/13 Javascript
canvas实现粒子时钟效果
2017/02/06 Javascript
vue实现微信分享朋友圈,发送朋友的示例讲解
2018/02/10 Javascript
Angular网络请求的封装方法
2018/05/22 Javascript
基于jQuery ztree实现表格风格的树状结构
2018/08/31 jQuery
layui添加动态菜单与选项卡 AJAX请求的例子
2019/09/25 Javascript
浅谈Vue.js之初始化el以及数据的绑定说明
2019/11/14 Javascript
详解Vue数据驱动原理
2020/11/17 Javascript
基于Vue2实现移动端图片上传、压缩、拖拽排序、拖拽删除功能
2021/01/05 Vue.js
[02:08]2014DOTA2国际邀请赛 430专访:力争取得小组前二
2014/07/11 DOTA
[16:56]教你分分钟做大人:司夜刺客
2014/10/30 DOTA
Python MD5加密实例详解
2017/08/02 Python
对TensorFlow的assign赋值用法详解
2018/07/30 Python
python消费kafka数据批量插入到es的方法
2018/12/27 Python
对Python 多线程统计所有csv文件的行数方法详解
2019/02/12 Python
Flask中endpoint的理解(小结)
2019/12/11 Python
pytorch梯度剪裁方式
2020/02/04 Python
Windows下Pycharm远程连接虚拟机中Centos下的Python环境(图文教程详解)
2020/03/19 Python
英国最受欢迎的手表网站:Watch Shop
2016/10/21 全球购物
网络安全方面的面试题
2015/11/04 面试题
实验教师岗位职责
2014/02/13 职场文书
财务务虚会发言材料
2014/10/20 职场文书
公司总经理岗位职责
2015/04/01 职场文书
利用Selenium添加cookie实现自动登录的示例代码(fofa)
2021/05/08 Python
MySQL提升大量数据查询效率的优化神器
2022/07/07 MySQL
python高温预警数据获取实例
2022/07/23 Python