zoukankan      html  css  js  c++  java
  • Javascript中Math.max和Math.max.apply的区别和用法


    最近在做一个小案例的时候遇到了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 就能自动生成编号并且是自增的。

  • 相关阅读:
    模板语言的作用及实例
    模板语言
    轮播图实例
    render,render_to_redponse,locals,redirect重定向
    setting中三个重要参数
    python中的Celery基本使用
    python中的Redis基本使用
    DRF之JWT认证
    DRF之过滤排序分页异常处理
    DRF之权限和频率限制
  • 原文地址:https://www.cnblogs.com/mingo233/p/13548990.html
Copyright © 2011-2022 走看看