zoukankan      html  css  js  c++  java
  • apply和call的用法总结

    这两个东西不常用,但是有时却又特别的方便。我也是从别的地方找到的学习例子,自己再写一遍。

    它们各自的定义:

    apply:应用某一对象的一个方法,用另一个对象替换当前对象

     

    call:调用一个对象的一个方法,以另一个对象替换当前对象。

     

    var child="aa";

    function demo(){

      var child="bb";

      console.log(this.child);

      console.log(this);

    }

    执行demo函数后,结果是(aa    window)

    我们都知道输出一个变量时候,都会在当前的作用域里面找,找不到沿着作用域链向上层找,找到

    最后还没有,就undefined了。

    但是此处,多了个this,经验证this指向了window

    定义一个对象 

    var obj={

      child:"cc"

    };

    demo.call(obj);

    此次的结果是( cc   obj),结论是函数demo的指向变成了obj,替换了window

    Math.max(1,2,3)      Max.min(1,2,3) 获取最大和最小的值,但是参数只能是一串数字

    Math.max.apply(null,arr);也可以获取数组中的最大值

    null参数,被Math.max替换,用apply来arr的每一项作为参数传给Math.max()

    操作数组的每一项map()

    var nums=[1,2,3,5,6];
    var result=nums.map(function(item,index,arr){
      return item*2
    })
    console.log(result);

    //[2,4,5,10,12]

  • 相关阅读:
    vim配置
    git rebase
    mongodb的docker-compose.yml
    Nginx配置BrowserRouter跟随react-router
    Flux Architecture & Redux Data Flow & redux & react-redux PPT
    from acwing 从算法数量推算算法复杂度
    evalRPN 逆波兰算术
    二分区间
    Flex布局
    Treap 模板
  • 原文地址:https://www.cnblogs.com/gaoxt/p/7159298.html
Copyright © 2011-2022 走看看