• 修改this的指向


    一、为什么要修改this的指向

    在某些业务场景中需要修改this的指向,才能实现

    二、怎么修改this的指向

    1. call()方法,语法:函数名.call(目标对象,实参列表....).目标对象就是你要让this指向的对象
    2. apply()方法,语法:函数名.apply(目标对象,实参列表)
    3. bind()方法,语法:函数名.bind(目标对象,实参列表)
    4. function abc(n1,n2){
                      console.log("sbc方法别调用了",this,n1,n2);
                  }
                  abc(100,200);//Window 100 200
                  abc.call(div1,100,200);//sbc方法别调用了 <div id=​"div1">​</div>​ 100 200
                  abc.call(100,100,200);//sbc方法别调用了 Number 100 200
                  abc.apply(document.body,[111,113]);//sbc方法别调用了 <body>​…​</body>​ 111 113
                  var newFunc=abc.bind(document.documentElement,333,332);
      //sbc方法别调用了 <html>​<head>​…​</head>​<body>​…​</body>​</html>​ 333 332 newFunc();
    5. Call和apply的区别仅仅是传实参的区别

      1.call是把实参一直往后写,apply是把实参放到一个数组里

    6. bind与call和apply的区别是调用时机的区别

      1.call和apply在修改this指向的同时会立刻调用该函数,bind在修改this指向只后会不立刻调用,而是返回一个修改完this指向的新函数,需要我们手动调用

    三、面试题这三个方法的区别

    勤学似春起之苗,不见其增,日有所长; 辍学如磨刀之石,不见其损,日所有亏!
  • 相关阅读:
    准确且巧妙的躲过了正确答案;
    百思不得其解,终得妙笔生花;
    考后小反思
    第一次接触oi知识对其分析。
    0515比赛感慨
    变量问题——赋值问题
    oi集训第七天感慨
    OI集训第五天总结(似乎是第一个正经题目)
    OI萌新第四天的渺(考)小(试)发(总)言(结)
    刚刚入Oi坑两天的萌新对于今天的吐槽
  • 原文地址:https://www.cnblogs.com/qiaozhiming123/p/14628880.html
Copyright © 2020-2023  润新知