Belajar Functional Programming JavaScript
  • Introduction
  • Bab 01: Apa Yang Pernah Kita Lakukan?
  • Bab 02: Fungsi Kelas Satu (First Class Function)
  • Bab 03: Kebahagiaan Murni dengan Fungsi Murni (Pure Function)
  • Bab 04: Currying (Kari)
  • Bab 05: Coding dengan Composing
  • Bab 06: Contoh Aplikasi
  • Bab 07: Hindley-Milner dan Saya
  • Bab 08: Tupperware
  • Bab 09: Monadic Onions
  • Bab 10: Aplikatif Functors
  • Bab 11: Transformasi Lagi, Secara Alami
  • Bab 12: Melintasi Batu
  • Bab 13: Monoid Menyatukan Semuanya
  • Lampiran A: Dukungan Fungsi Esensial
  • Lampiran B: Dukungan Struktur Aljabar
  • Lampiran C: Utilitas Pointfree
Powered by GitBook
On this page
  • add
  • append
  • chain
  • concat
  • eq
  • filter
  • flip
  • forEach
  • head
  • intercalate
  • join
  • last
  • map
  • match
  • prop
  • reduce
  • replace
  • reverse
  • safeHead
  • safeLast
  • safeProp
  • sequence
  • sortBy
  • split
  • take
  • toLowerCase
  • toString
  • toUpperCase
  • traverse
  • unsafePerformIO

Was this helpful?

Lampiran C: Utilitas Pointfree

PreviousLampiran B: Dukungan Struktur Aljabar

Last updated 3 years ago

Was this helpful?

Dalam lampiran ini, Anda akan menemukan beberapa implementasi JavaScript dasar dari berbagai fungsi yang dijelaskan dalam buku ini.

Ingatlah bahwa implementasi ini mungkin bukan implementasi tercepat atau paling efisien di luar sana; mereka dibuat hanya untuk tujuan pendidikan.

Untuk menemukan fungsi yang lebih siap produksi, lihat , , atau .

Perhatikan bahwa fungsi mengacu pada curry & compose fungsi yang didefinisikan dalam .

add

// add :: Number -> Number -> Number
const add = curry((a, b) => a + b);

append

// append :: String -> String -> String
const append = flip(concat);

chain

// chain :: Monad m => (a -> m b) -> m a -> m b
const chain = curry((fn, m) => m.chain(fn));

concat

// concat :: String -> String -> String
const concat = curry((a, b) => a.concat(b));

eq

// eq :: Eq a => a -> a -> Boolean
const eq = curry((a, b) => a === b);

filter

// filter :: (a -> Boolean) -> [a] -> [a]
const filter = curry((fn, xs) => xs.filter(fn));

flip

// flip :: (a -> b -> c) -> b -> a -> c
const flip = curry((fn, a, b) => fn(b, a));

forEach

// forEach :: (a -> ()) -> [a] -> ()
const forEach = curry((fn, xs) => xs.forEach(fn));

head

// head :: [a] -> a
const head = (xs) => xs[0];

intercalate

// intercalate :: String -> [String] -> String
const intercalate = curry((str, xs) => xs.join(str));

join

// join :: Monad m => m (m a) -> m a
const join = (m) => m.join();

last

// last :: [a] -> a
const last = (xs) => xs[xs.length - 1];

map

// map :: Functor f => (a -> b) -> f a -> f b
const map = curry((fn, f) => f.map(fn));

match

// match :: RegExp -> String -> Boolean
const match = curry((re, str) => re.test(str));

prop

// prop :: String -> Object -> a
const prop = curry((p, obj) => obj[p]);

reduce

// reduce :: (b -> a -> b) -> b -> [a] -> b
const reduce = curry((fn, zero, xs) => xs.reduce(fn, zero));

replace

// replace :: RegExp -> String -> String -> String
const replace = curry((re, rpl, str) => str.replace(re, rpl));

reverse

// reverse :: [a] -> [a]
const reverse = (x) =>
  Array.isArray(x) ? x.reverse() : x.split("").reverse().join("");

safeHead

// safeHead :: [a] -> Maybe a
const safeHead = compose(Maybe.of, head);

safeLast

// safeLast :: [a] -> Maybe a
const safeLast = compose(Maybe.of, last);

safeProp

// safeProp :: String -> Object -> Maybe a
const safeProp = curry((p, obj) => compose(Maybe.of, prop(p))(obj));

sequence

// sequence :: (Applicative f, Traversable t) => (a -> f a) -> t (f a) -> f (t a)
const sequence = curry((of, f) => f.sequence(of));

sortBy

// sortBy :: Ord b => (a -> b) -> [a] -> [a]
const sortBy = curry((fn, xs) =>
  xs.sort((a, b) => {
    if (fn(a) === fn(b)) {
      return 0;
    }

    return fn(a) > fn(b) ? 1 : -1;
  })
);

split

// split :: String -> String -> [String]
const split = curry((sep, str) => str.split(sep));

take

// take :: Number -> [a] -> [a]
const take = curry((n, xs) => xs.slice(0, n));

toLowerCase

// toLowerCase :: String -> String
const toLowerCase = (s) => s.toLowerCase();

toString

// toString :: a -> String
const toString = String;

toUpperCase

// toUpperCase :: String -> String
const toUpperCase = (s) => s.toUpperCase();

traverse

// traverse :: (Applicative f, Traversable t) => (a -> f a) -> (a -> f b) -> t a -> f (t b)
const traverse = curry((of, fn, f) => f.traverse(of, fn));

unsafePerformIO

// unsafePerformIO :: IO a -> a
const unsafePerformIO = (io) => io.unsafePerformIO();
ramda
lodash
folktale
Lampiran A