手写实现 bind 函数

javascript 复制代码
Function.prototype.myBind = function(context) {
    if (typeof this !== 'function') {
        return
    }
    const args = [...arguments].slice(1)
    const fn = this
    return function Fn() {
        // 判断函数作为构造函数的情况,这个时候需要传入当前的函数的this给apply调用,其余情况都传入指定的上下文对象
        const target = this instanceof Fn ? this : context
        return  fn.apply(target, args.concat([...arguments]))
       
    }
}

function setName(name) {
    this.name = name
}

const obj = {
    age: 1
}
const setName1 = setName.bind(obj)
setName1('test')
console.log('正确结果',  obj)
const setName2 = setName.myBind(obj)
setName1('miome')
console.log('正确结果',  obj)
相关推荐
python猿10 分钟前
打卡Python王者归来--第30天
开发语言·python
qq_3349031510 分钟前
嵌入式C++驱动开发
开发语言·c++·算法
阿贵---21 分钟前
C++代码规范化工具
开发语言·c++·算法
暮冬-  Gentle°29 分钟前
自定义内存检测工具
开发语言·c++·算法
一直都在57230 分钟前
Java死锁
java·开发语言
娇娇yyyyyy32 分钟前
QT编程(15): Qt 按键事件和定时器事件
开发语言·qt
2501_945424801 小时前
C++编译期矩阵运算
开发语言·c++·算法
yy我不解释1 小时前
关于comfyui的mmaudio音频生成插件时时间不一致问题(三)
开发语言·python·ai作画·音视频·comfyui
2301_815482931 小时前
C++中的类型标签分发
开发语言·c++·算法
SuperEugene1 小时前
Vue3 模板语法规范实战:v-if/v-for 不混用 + 表达式精简,避坑指南|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架