手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JavaScript函数中关于valueOf和toString的理解
JavaScript函数中关于valueOf和toString的理解
摘要:今天看到一个试题,实现如下语法的功能:vara=add(2)(3)(4);//9这个就是一个高阶函数的应用,分析:add(2)会返回一个函数...

今天看到一个试题,实现如下语法的功能:

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://www.cnblogs.com/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。

【JavaScript函数中关于valueOf和toString的理解】相关文章:

JavaScript中的acos()方法使用详解

JavaScript中eval函数的问题

JavaScript获取两个数组交集的方法

JavaScript中的setUTCDate()方法使用详解

JavaScript中toString()方法的使用详解

Javascript中Date类型和Math类型详解

浅谈javascript中for in 和 for each in的区别

JavaScript中的substr()方法使用详解

JavaScript中用toString()方法返回时间为字符串

JavaScript中的Math.E属性使用详解

精品推荐
分类导航