zoukankan      html  css  js  c++  java
  • 对call() apply() 方法的简单理解

      真的是非常简单的理解,我知道的并不多,在网上查找了很多的资料,还是只能了解一点皮毛,下面来整理出来,方便以后深入的去学习,也是对目前知道的知识点的巩固。

    整理一些网上的经典解答:

    1.一句话区分call 和apply

    obj1.call(obj2,arg1,arg2,arg3) == obj1.apply(obj2,arguments) == obj2.foo(arg1,arg2,arg3)

    thisA.functionA.apply(thisB,[arg1,arg2,...]) == thisA.functionA.call(thisB,arg1,arg2,...) == thisB.functionA(arg1,arg2,...)

    • obj2如果为空则this指向window对象
    • call 和apply的区别在于:call接的参数是固定的,按照顺序输入。apply接收的参数是一个数组。
    • 什么时候使用call或者apply?当参数是固定的时候一般使用call,如果参数不确定或者参数是一个数组时需要使用apply.
    • 上面的话理解成 obj2调用obj1的方法。对象thisB调用thisA的functionA方法

    2.理解obj2如果为空则this指向window

    1 obj1.call(obj2,a,b);
    2 //等价于
    3 if(obj2!==null){
    4     obj1.this=obj2;
    5     }else{
    6     obj1.this=window;
    7 }
    8 obj1(a,b);

    3.摘自javascript高级程序书本中的代码

    1 var values = [1,2,3,4,5,6,9];
    2 var max = Math.max.apply(Math,values);
    3 console.log(max);//9

    这里Math当作apply()的第一个参数我无法理解,max()方法是Math对象下面的一个方法,values为一个数组对象,需要去借用Math对象下面的max()方法。

    1 var values = [1,2,3,4,5,6,9];
    2 var max = Math.max.apply(Array,values);
    3 console.log(max);//9
    1 var values = [1,2,3,4,5,6,9];
    2 var max = Math.max.apply(this,values);
    3 console.log(max);//9

    发现用Array或者this代替 Math尽然都会输出9.

    4.一个例子

    call和apply可以用来重新定义函数的执行环境,也就是this的指向

    1 function changgeStyle(attr,value){
    2             this.style[attr] = value;
    3         }
    4 var box = document.getElementById("box");
    5 window.changgeStyle.call(box,"height","200px");

    changgeStyle()为window对象下面的方法,那么如何把window对象的方法转移到box对象上呢,通过动态的改变this的指向,也就是相当于借用window.changgeStyle()的方法,通过call方法把 window.changgeStyle("height","200px")变成了box.changgeStyle("height","200px").

    总结:就是自己没有的属性或者方法,通过改变函数的执行环境(this的指向),或者通俗点来说就是借用别人的属性或者方法来执行操作。

  • 相关阅读:
    超出范围样式...
    CSS 滚动条设置
    js 数组全包含
    vue字段为空过滤器
    window.open 打开的新页签会携带sessionStorage中的数据
    ES6的解构赋值与深拷贝和浅拷贝
    vue中怎么处理多个单选框,且单选框互不影响的方案
    h5项目中关于ios手机软键盘导致页面变形的完美解决方案
    vue项目中关于微信分享的坑,以及安卓和ios获取location.href不同的处理
    navicat连接mysql报错1251的解决方法
  • 原文地址:https://www.cnblogs.com/yewenxiang/p/6166500.html
Copyright © 2011-2022 走看看