-
add(1)(2)(3)
// 自己写的
let add = function () {
let times = 0;
let num = 0;
return function a(item) {
num += item;
times++;
return times < 3 ? a : num;
}
}()
console.log(add(1)(2)(3))
// 改进后可以满足的传法add(1,2)(3) add(1)(2,3) add(1,2,3)
let add1 = function () {
let len = 0;
let num = 0;
return function a(...item) {
len += arguments.length;
[...arguments].forEach(element => {
num += element;
});
if (len < 3) {
return a;
} else {
return num;
}
}
}()
console.log(add1(1, 2)(3))
// 这样有一个缺点就是,第二次调用的时候num没有被销毁
// 我改进了一下
let add2 = function () {
let len = 0;
let num = 0;
return function a(...item) {
len += arguments.length;
[...arguments].forEach(element => {
num += element;
});
if (len < 3) {
return a;
} else {
len = 0;
let temp = num;
num = 0;
return temp;
}
}
}()
console.log(add2(1)(2)(3))
console.log(add2(1, 2)(3))
// 老师教的
function curring(fn) {
const inner = (args = []) => {
return args.length >= fn.length ? fn(...args) : (...userArgs) => inner([...args, ...userArgs]);
}
return inner();
}
function sum(a, b, c) {
return a + b + c
}
let add = curring(sum);
console.log(add(1)(2)(3))
console.log(add(1, 2)(3))
-
类型判断
function curring(fn) {
const inner = (args = []) => {
return args.length >= fn.length ? fn(...args) : (userArgs) => inner([...args, userArgs]);
}
return inner();
}
function isType(typing, val) {
return Object.prototype.toString.call(val) == `[object ${typing}]`;
}
let util = {};
['String', 'Number', 'Boolean', 'Null', 'Undefined'].forEach(type => {
util['is' + type] = curring(isType)(type);
})
console.log(util.isString(123));
console.log(util.isNumber(123));