Function currying - garevna/js-course GitHub Wiki

:mortar_board: Биндинг и каррирование


:mortar_board: Currying

Каррирование заключается в следующем:

если при вызове функции 1 передать ей не все параметры,

то она вернет функцию 2, параметры которой будут

недостающими параметрами функции 1,

а выходные данные - результатом функции 1

function currying ( first, second ) {
    return arguments.length === 0 ? null :
        arguments.length === 1 ? 
            function ( second ) {
                return arguments.length === 1 ? 
                    [ first, second ] : null
            } : [ first, second ]
}

var curried = currying ( "Google" )

console.log ( curried )
Результат в консоли:
ƒ ( second ) {
    return arguments.length === 1 ? 
        [ first, second ] : null
}

Вызовем функцию curried

curried ()               // null
curried ( "Mozilla" )   // ► (2) ["Google", "Mozilla"]

Воспользуемся приемом Currying для создания функций с заданным контекстом и фиксированным значением первого аргумента

:coffee: :five:

var test = function ( args ) {
    return Array.from ( args ).toString()
}

function func () {
    console.log (
    `Функция func вызвана в контексте объекта ${this.name} 
     c аргументами ${this.test( arguments )}` ) 
}

var figure = { name: "figure", test: test }

var circleFunc = func.bind ( figure, "circle" )
var rectFunc = func.bind ( figure, "rect" )
var lineFunc = func.bind ( figure, "line" )

circleFunc ( 100, 120, 80 )
rectFunc ( 50, 50, 150, 150 )
lineFunc ( 20, 30, 200, 200 )
Результат в консоли:
Функция func вызвана в контексте объекта figure 
     c аргументами circle,100,120,80
Функция func вызвана в контексте объекта figure 
     c аргументами rect,50,50,150,150
Функция func вызвана в контексте объекта figure 
     c аргументами line,20,30,200,200

:coffee: :six:

function sample ( first, second, third ) {
    function test ( arg ) {
        return Array.from ( arguments )
    }
    return [
        test.bind ( null, first ),
        test.bind ( null, first, second ),
        test.bind ( null, first, second, third )
    ]
}

var test = sample ( "Google", "Mozilla", "Safari" )

console.log ( test[0]( "IE" ) )
console.log ( test[1]( "IE" ) )
console.log ( test[2]( "IE" ) )
Результат в консоли:
► (2) ["Google", "IE"]
► (3) ["Google", "Mozilla", "IE"]
► (4) ["Google", "Mozilla", "Safari", "IE"]

:coffee: :seven:

function sample ( first, second, third ) {
    function test ( arg ) {
        return Array.from ( arguments )
    }
    var one = test.bind ( null, first )
    var two = one.bind ( null, second )
    var three = two.bind ( null, third )
    return [ one, two, three ]
}

var test = sample ( "Google", "Mozilla", "Safari" )

console.log ( test[0]( "IE" ) )
console.log ( test[1]( "IE" ) )
console.log ( test[2]( "IE" ) )
Результат в консоли:
► (2) ["Google", "IE"]
► (3) ["Google", "Mozilla", "IE"]
► (4) ["Google", "Mozilla", "Safari", "IE"]