Tambahkan dengan jumlah kurung yang banyak
Buatlah sebuah fungsi sum
yang harus bekerja seperti ini:
sum(1)(2) == 3; // 1 + 2
sum(1)(2)(3) == 6; // 1 + 2 + 3
sum(5)(-1)(2) == 6
sum(6)(-1)(-2)(-3) == 0
sum(0)(1)(2)(3)(4)(5) == 15
Catatan. Kamu mungkin perlu untuk mengatur objek kostum menjadi perngubah primitif didalam fungsi kamu.
- Untuk membuat semuanya bekerja entah bagaimana, hasil dari
sum
haruslah sebuah fungsi. - Fungsi harus menyimpan nilai sekarang yang berada diantara pemanggilan didalam memori.
- Menurut tasknya, fungsinya harus menjadi angka ketika digunakan didalam
==
. Fungsi adalah objek, jadi perubahan terjasi seperti yang dideskripsikan didalam bab Menolak konversi primitif, dan kita bisa menyediakan metode milik kita yang mengembalikan angkanya.
Sekarang angkanya:
function sum(a) {
let currentSum = a;
function f(b) {
currentSum += b;
return f;
}
f.toString = function() {
return currentSum;
};
return f;
}
alert( sum(1)(2) ); // 3
alert( sum(5)(-1)(2) ); // 6
alert( sum(6)(-1)(-2)(-3) ); // 0
alert( sum(0)(1)(2)(3)(4)(5) ); // 15
Perhatikan baik-baik bahwa fungsi sum
sebenarnya hanya bekerja satu kali. Itu mengembalikan fungsi f
.
Lalu, untuk setiap pemanggilan selanjutnya f
menambahkan parameternya kedlaam currentSum
, dan mengembalikan dirinya sendiri.
Tidak terdapat rekursi di akhir baris dari f
.
Ini adalah bagaimana rekursi terlihat:
function f(b) {
currentSum += b;
return f(); // <-- pemanggilan rekursi
}
Dan didalam kasus kita, kita hanya mengembalikan fungsinya, tanpa memanggilnya:
function f(b) {
currentSum += b;
return f; // <-- tidak memanggil dirinya-sendiri, hanya mengembalikan dirinya
}
f
ini akan digunakan didalam pemanggilan selanjutnya, dan lagi akan mengembalikan dirinya-sendiri, berapa kalipun seperti yang dibutuhkan. Lalu, ketika digunakan sebagai angka atau sebuah string ??? toString
mengembalikan currentSum
. Kita jadi bisa menggunakan Symbol.toPrimitive
atau valueOf
disini sebagai perubahan.