[Functional Programming] Function modelling -- 10. Free Monads
Free monads, it provides a way to modelling functions as Data type. So composing/chaining data types to form the application.
We also need something called `interpret` which can automaticlly do partten matching and do actual tasks.
Read more: https://medium.com/@drboolean/free-er-monads-in-js-f5a59e7abc82
https://medium.com/@drboolean/free-er-monads-in-js-pt2-8ab3b9efa510
So, part one, how to modelling function as data type:
const { liftF } = require("../free");
const { Id } = require("../types");
const { taggedSum } = require("daggy");
const Http = taggedSum("Http", {
Get: ["url"],
Post: ["url", "body"],
});
// Free Http Get
const httpGet = (url) => liftF(Http.Get(url));
// Free Http Post
const httpPost = (url, body) => liftF(Http.Post(url, body));
Using 'daggy' to build Http object.
So if you call:
Http.Get('/home') // {url: '/home'}
Then compose to an application:
const app = () =>
httpGet("/home").chain((contents) => httpPost("/analytics", contents));
const res = app().foldMap(interpret, Id.of);
Last thing is the 'interpret':
const interpret = (x) =>
x.cata({
Get: (url) => Id.of(`contents for ${url}`),
Post: (url, body) => Id.of(`Post ${body} to ${url}`),
});
--
Full code:
const { liftF } = require("../free");
const { Id } = require("../types");
const { taggedSum } = require("daggy");
/**
* Data type to repersent function:
*
*
* httpGet = url => HttpGet(url)
*
* HttpGet(url)
* .chain(contents => HttpPost('/ayalytics', contents))
*
*/
const Http = taggedSum("Http", {
Get: ["url"],
Post: ["url", "body"],
});
// Free Http Get
const httpGet = (url) => liftF(Http.Get(url));
// Free Http Post
const httpPost = (url, body) => liftF(Http.Post(url, body));
const interpret = (x) =>
x.cata({
Get: (url) => Id.of(`contents for ${url}`),
Post: (url, body) => Id.of(`Post ${body} to ${url}`),
});
const app = () =>
httpGet("/home").chain((contents) => httpPost("/analytics", contents));
const res = app().foldMap(interpret, Id.of);
console.log(res.extract());
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.