数字直接调用函数:(5).fn1(2).fn2(3)实现5-2+3

起因

在网上无意间看到这么一道题,第一次实践,直接报错,所以记录下来加深记忆

过程

一看到数字可以调用函数,最先想到的类似的场景就是 (5).toFixed(2),那么接下来,有两个思路了
1、重写Number原型对象中的方法
2、在Number的原型对象中添加方法
思路一在实践过程中,终于在 bind方法中迷失了自我,最后放弃治疗,先记下来以后再战。
思路二,本人没有仔细考虑,直接写了下面一段代码
Number.prototype.fn1 = function (item){
    const value = this.valueOf(); // value

    const result = value - item;

    return result;
};
        
Number.prototype.fn2 = function (item){
    const value = this.valueOf(); // value

    const result = value + item;

    return result;
}
        
console.log((5).fn1(2).fn2(3));
结果就是报错: fn1未定义
打断点,发现没有调用 fn1,而是在 fn2定义的时候直接报错,在控制台打印 Number.prototype,发现 fn1在打印出的对象中, fn2却没有出现。
一番死脑筋的查询资料,最终在mdn上,发现 Number.prototypeconfigurable属性为 false

解决

那么问题好办了, Number.prototype继承于 Object.prototypeObject.prototypeconfigurable属性值是 true。更改代码如下
Object.prototype.fn1 = function (item){
    const value = this.valueOf(); // value

    const result = value - item;

    return (result);
    // return result; 不加()的话,后面的.会被识别为小数点哦
};
        
Object.prototype.fn2 = function (item){
    const value = this.valueOf(); // value

    const result = value + item;

    return result;
}
        
console.log((5).fn1(2).fn2(3));
ok,问题到这里结束,另外,随手查了 String.prototypeBoolean.prototype,它们的 configurable属性值也是 false

遗留问题

其实,删除掉上述 Number.prototype.fn2,只执行 (5).fn1(2)是可以的,为什么加一个属性可以,加两个却不行,正在研究,也希望有高人解答。
Number.prototype.fn1 = function (item){
    const value = this.valueOf(); // value

    const result = value - item;

    return (result);
};
        
console.log((5).fn1(2));
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值