数字直接调用函数:(5).fn1(2).fn2(3)实现5-2+3
栏目: JavaScript · 发布时间: 5年前
内容简介:在网上无意间看到这么一道题,第一次实践,直接报错,所以记录下来加深记忆一看到数字可以调用函数,最先想到的类似的场景就是1、重写Number原型对象中的方法
起因
在网上无意间看到这么一道题,第一次实践,直接报错,所以记录下来加深记忆
过程
一看到数字可以调用函数,最先想到的类似的场景就是 (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.prototype
的 configurable
属性为 false
解决
那么问题好办了, Number.prototype
继承于 Object.prototype
, Object.prototype
的 configurable
属性值是 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.prototype
和 Boolean.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));
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Python 函数调用&定义函数&函数参数
- Linux内核如何替换内核函数并调用原始函数
- gdb 如何调用函数?
- 汇编层面分析函数调用
- 理解 Golang 的函数调用
- Wasm 介绍(六):间接函数调用
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Flash ActionScript 3.0 动画高级教程
Keith Peters / 苏金国、荆涛 / 人民邮电出版社 / 2010-1 / 65.00元
《Flash ActionScript 3.0 动画高级教程》是介绍Flash 10 ActionScript动画高级技术的经典之作,是作者在这一领域中多年实践经验的结晶。书中不仅涵盖了3D、最新绘图API以及Pixel Bender等Flash 10 ActionScript特性,深入介绍了碰撞检测、转向、寻路等Flash游戏开发技术,还通过实例具体讲解了等角投影和数值积分的基本理论和应用。 ......一起来看看 《Flash ActionScript 3.0 动画高级教程》 这本书的介绍吧!