JavaScript函数中关于valueOf和toString的理解
网络编程 2021-07-04 19:59www.168986.cn编程入门
本文给大家介绍JavaScript函数中关于valueOf和toString的理解,简单的说就是需要转换为字符串时,会调用toString,需要转换为数字时需要调用valueOf。对js valueof tostring知识感兴趣的朋友一起学习吧
今天看到一个试题,实现如下语法的功能
var a = add(2)(3)(4); //9
这个就是一个高阶函数的应用,分析add(2)会返回一个函数,add(2)(3)也会返回一个函数,add(2)(3)(4)返回一个数值。
实现
function add(num1){ return function(num2){ return function(num3){ return num1+num2+num3; } } } add(2)(3)(4);//9
这个没有错的,可以完美解决问题。
优化这里只讨论关于高阶函数的部分,对于更好的解决方案,可以实现无限这种调用,
//方法一 function add(a) { var temp = function(b) { return add(a + b); } temp.valueOf = temp.toString = function() { return a; }; return temp; } add(2)(3)(4)(5);//14 //方法二、另看到一种很飘逸的写法(来自Gaubee) function add(num){ num += ~~add; add.num = num; return add; } add.valueOf = add.toString = function(){return add.num}; var a= add(3)(4)(5)(6); // 18 //方法二注释其实就相当于,只不过对函数应用了自定义属性,用于存储值。 ;(function(){ var sum=0; function add(num){ sum+=num; return add; } add.valueOf=add.toString=function(){return sum;} window.add=add; })() var a= add(3)(4)(5)(6); // 18[/code]
这是我在[url=http://.blogs./wengxuesong/p/5577683.html]博客园[/url]看到的文章中写的,对于其中的方法一和方法二 一直不理解,也尝试在控制台输出 [code=javascript,javascript 代码,true]function 9
var temp = function() { } temp.valueOf = function() { return 2; } temp.toString = function() { return 'hahh'; } alert(temp); console.log(2 temp);
需要转换为字符串时,会调用toString,需要转换为数字时需要调用valueOf。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程