首页 > 移动平台 > 详细

手写 call、apply 及 bind 函数

时间:2021-08-23 19:23:11      阅读:15      评论:0      收藏:0      [点我收藏+]

1、Call 函数实现

// Call函数实现
Function.prototype.myCall = function(context) {
    // 判断对象
    if (typeof this !== "function") {
        console.error("Type Error");
    }
    // 获取参数
    let args = [...arguments].slice(1);
    let result = null;
    // 判断context 是否传入,如果未传入则设置为 window
    context = context || window;
    // 将调用函数设为对象的方法
    context._fn = this;
    // 调用函数
    result = context._fn(...args);
    // 将属性删除
    delete context._fn;
    return result;
}

2、Apply 函数实现

// Apply 函数实现
Function.prototype.myApply = function(context) {
    // 判断调用对象是否为函数
    if (typeof this !== "function") {
        throw new TypeError("Type Error");
    }
    let result = null;
    // 判断context 是否存在,如果未传入则为 window
    context = context || window;
    // 将函数设为对象的方法
    context._fn = this;
    // 调用方法
    let agrArr = arguments[1];
    if (Array.isArray(agrArr)) {
        result = context._fn(...agrArr);
    } else {
        result = context._fn();
    }
    // 将属性删除
    delete context._fn;
    return result;
}

3、Bind 函数实现

// Bind 函数实现
Function.prototype.myBind = function(context) {
    // 判断调用对象是否为函数
    if (typeof this !== ‘function‘) {
        throw new TypeError("Type Error");
    }
    // 获取参数
    let args = [...arguments].slice(1);
    let fn = this;
    return function Fn() {
        // 根据调用方式,传入不同绑定值
        return fn.apply(
            this instanceof Fn ? this : context,
            args.concat(...arguments)
        );
    }
}

 

手写 call、apply 及 bind 函数

原文:https://www.cnblogs.com/fxlsoft/p/15177143.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!