有个面试题,看了一些大佬写的代码有些疑问,ret本来就是函数了,ret.toString跟ret.valueOf为什么要这样写呢?
`
ret.toString = function () {
return res
}
ret.valueOf = function () {
return res
}
`
有个面试题,看了一些大佬写的代码有些疑问,ret本来就是函数了,ret.toString跟ret.valueOf为什么要这样写呢?
`
ret.toString = function () {
return res
}
ret.valueOf = function () {
return res
}
`
解构这些估计你都懂了,讲以下两个
add 返回 ret 这个 function 是为了 add()()()()
能跟无限个括号
var j = (function() {
return function () {
console.log('yo')
return j
}
}())
j()()()() // yo yo yo yo
如果你只想 log 的话其实不用改写 toString 或者 valueOf,但是最后一个括号要作为值返回出去,而前面的括号要作为函数返回出去,这里就用了 toString 和 valueOf 自动类型转换
var j = (function() {
let i = 0
return function () {
i += 1
return i > 3 ? i : j // 总要想个办法在最后返回值而不是返回函数
}
}())
console.log(j()()()) // 三个括号输出 [function],四个括号输出 4
10 回答11.7k 阅读
2 回答3.2k 阅读✓ 已解决
4 回答2.2k 阅读✓ 已解决
3 回答1.2k 阅读✓ 已解决
1 回答1.8k 阅读✓ 已解决
3 回答835 阅读✓ 已解决
3 回答1k 阅读✓ 已解决
修改toString与valueOf函数,这里应该是在ret上添加两个方法toString与valueOf,就和vue里的数据侦测原理一样,修改了对象的set与get方法.