js实现一个既可以当做对象调用也可以当做函数调用的方法

定义一个方法,让他既可以当做函数直接调用,也可以当做对象调用。

// 创建一个函数
function MainFn(params){

    this.MainFnObj = {
        name: 'mainFnName'
    }
    return this;
}
// 执行函数
MainFn.prototype.execute = function (data){
    console.log(data)
    return
}
// 给实例添加属性
MainFn.prototype.children1 = function (data){
    return this.execute({name:'子函数1',...data})
}
MainFn.prototype.children2 = function (data){
    return this.execute({name:'子函数2',...data})
}
MainFn.prototype.children3 = function (data){
    return this.execute({name:'子函数3',...data})
}

let context = new MainFn();
let instance = MainFn.prototype.execute.bind(context);
// 扩展instance属性
for(let i of Object.keys(MainFn.prototype)){
    instance[i] = MainFn.prototype[i].bind(context);
}
for(let i of Object.keys(context)){
    instance[i] = context[i]
}

console.log(instance.MainFnObj)
instance({name:'name1'})
instance.children1({name:'children1'})
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值