JavaScript
发布时间:2022-04-16 发布网站:大佬教程 code.js-code.com
大佬教程收集整理的这篇文章主要介绍了JavaScript函数中关于valueOf和toString的理解,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
今天看到一个试题,实现如下语法的功能:
); //9
这个就是一个高阶函数的应用,分析:add(2)会返回一个函数,add(2)(3)也会返回一个函数,最后add(2)(3)(4)返回一个数值。
实现:
{
return function(num2)
{
return function(num3)
{
return num1+num2+num3;
}
}
}
add(2)(3)(4
);//9
这个没有错的,可以完美解决问题。
优化:这里只讨论关于高阶函数的部分,对于更好的解决方案,可以实现无限这种调用,
{
var temp = function(b)
{
return add(a + b
);
}
temp.valueOf = temp.to
String = 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.to
String = 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.to
String=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
{
}
temp.valueOf = function()
{
return 2;
}
temp.to
String = function()
{
return 'hahh';
}
alert(tem
p);
console.log(2 * tem
p);
需要转换为字符串时,会调用toString,需要转换为数字时需要调用valueOf。
大佬总结
以上是大佬教程为你收集整理的JavaScript函数中关于valueOf和toString的理解全部内容,希望文章能够帮你解决JavaScript函数中关于valueOf和toString的理解所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。