• call、apply区别


    相同点:都是重定向this指针的方法。
    不同点:call和apply的第二个参数不相同,call是若干个参数的列表。apply是一个数组
    
    手写一个call方法
    
    
    // 在这之前需要重新认识一下call方法的执行操作
    let mock = { value : 1 };
    function mockNum(){
     console.log('value',this.value)
    }
    mockNum.call(mock) // 改变了函数中this的指向,当前this指向了mock对象
    
    转换一下实现方法就是
    
    let mock = {
      value:1;
      mockNum:function(){
         console.log('value',this.value)
      }
    }
    mock.mockNum();
    所以经过上面这个操作的演化而来的结果就是如下步骤:
    1. 将函数设为一个对象的属性
    2. 并将这个函数的属性调用
    3. 删除该函数
    
    Function.prototype.Mycall = function(context){
      let obj = context || window;
      obj.fn = this; //   这一步可以看做是this其实就指的当前函数。
      let args = [...arguments].slice(1); // 返回删除第一个元素的数组;
      let result = obj.fn(...args); // 调用函数
      delete obj.fn;
      return result;
    }
    
    // 操作一下
    let mock = { value : 1 };
    function mockNum(){
      console.log('value',this.value);
    }
    mockNum.Mycall(mock) // value 1

    然后根据上面的方法再手写一个apply方法

    Function.prototype.Myapply = function (context){
        let obj = context || window;
        obj.fn = this;
        let result = arguments[1] ? obj.fn(arguments[1]) : obj.fn([]);
        delete obj.fn;
        return result;
    }
    let mock3 = {
      arr: [1, 2, 3, 4, 5],
    };
    function arrx2(arr) {
      return this.arr.concat(arr).map((x) => x * 2);
    }
    console.log("arrx2", arrx2.myApply(mock3));

    bind方法

    bind方法是直接返回一个新的函数,需要手动去调用才能执行。
    
    创建一个新函数,当这个新函数被调用时,bind()方法的第一个参数将作为运行他的this,之后的一系列参数将会在传递的实参传入作为他的参数;
    特点:1. 返回一个函数。 2. 可以传入参数;
    手写一个bind方法
    
    例如:
    let foo = { value : 1 };
    function bar() {
      console.log('bindFoo',this.value);
      // return this.value // 考虑到函数可能有返回值
    }
    let bindFoo = bar.bind(foo);
    bindFoo() // 1  // 如果有返回值的情况下 bindFoo() === 1;
    
    Function.prototype.Mybind = function(obj){
      if(typeof this !== 'function') throw new Error('not a function');
      let self = this;
      let args = [...arguments].clice(1);
      return function F(){
        if(this instanceof F){
          return new self(...args,...arguments);
        }
        return self.apply(obj,args.concat([...arguments]));
      }
    }


  • 相关阅读:
    常用Linux命令的基本使用(不定时补充)
    利用油猴插件实现全网VIP视频免费看
    电脑开机显示被调用的对象已与其他客户端断开连接
    常见DOS命令
    Text函数对转换日期,调整数值,条件判断的应用技巧
    Excel常用函数
    Power BI(天猫双十一美妆销售数据分析)
    Power BI新建列与关系函数(三)
    Python_Bug
    Docker 初窥(有一大坑,注意根目录磁盘爆满问题,易导致开机黑屏)
  • 原文地址:https://www.cnblogs.com/Fairy-Tail-blogs/p/14943066.html
Copyright © 2020-2023  润新知