कॉलबैक को वैकल्पिक बनाने के बजाय, बस एक डिफ़ॉल्ट असाइन करें और इसे कॉल करें चाहे कोई भी हो
const identity = x =>
x
const save (..., callback = identity) {
// ...
return callback (...)
}
इस्तेमाल के बाद
save (...) // callback has no effect
save (..., console.log) // console.log is used as callback
ऐसी शैली को निरंतरता-गुजर शैली कहा जाता है । यहां एक वास्तविक उदाहरण है, combinations
जो एक ऐरे इनपुट के सभी संभावित संयोजनों को उत्पन्न करता है
const identity = x =>
x
const None =
Symbol ()
const combinations = ([ x = None, ...rest ], callback = identity) =>
x === None
? callback ([[]])
: combinations
( rest
, combs =>
callback (combs .concat (combs .map (c => [ x, ...c ])))
)
console.log (combinations (['A', 'B', 'C']))
// [ []
// , [ 'C' ]
// , [ 'B' ]
// , [ 'B', 'C' ]
// , [ 'A' ]
// , [ 'A', 'C' ]
// , [ 'A', 'B' ]
// , [ 'A', 'B', 'C' ]
// ]
क्योंकि combinations
निरंतरता-गुजर शैली में परिभाषित किया गया है, उपरोक्त कॉल प्रभावी रूप से समान है
combinations (['A', 'B', 'C'], console.log)
// [ []
// , [ 'C' ]
// , [ 'B' ]
// , [ 'B', 'C' ]
// , [ 'A' ]
// , [ 'A', 'C' ]
// , [ 'A', 'B' ]
// , [ 'A', 'B', 'C' ]
// ]
हम एक कस्टम निरंतरता भी पारित कर सकते हैं जो परिणाम के साथ कुछ और करता है
console.log (combinations (['A', 'B', 'C'], combs => combs.length))
// 8
// (8 total combinations)
निरंतर-गुजर शैली का उपयोग आश्चर्यजनक रूप से सुरुचिपूर्ण परिणामों के साथ किया जा सकता है
const first = (x, y) =>
x
const fibonacci = (n, callback = first) =>
n === 0
? callback (0, 1)
: fibonacci
( n - 1
, (a, b) => callback (b, a + b)
)
console.log (fibonacci (10)) // 55
// 55 is the 10th fibonacci number
// (0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, ...)
typeof callback !== undefined
तो बाहर छोड़'