Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
ES6時代の関数型プログラミング
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Kawabata Kazuki
January 30, 2017
Technology
1
750
ES6時代の関数型プログラミング
We Are Javascripters#3 #wajs #javascript
Kawabata Kazuki
January 30, 2017
Tweet
Share
More Decks by Kawabata Kazuki
See All by Kawabata Kazuki
AIでビットコインとアプリの未来を考えるワークショップ
cab1
0
13
AX時代のナレッジマネジメント.pdf
cab1
0
28
AX時代のオペレーション構築
cab1
0
20
AXを実現するマインドセット
cab1
0
47
Time2Build Kickoff
cab1
0
24
コロナ禍でのチームビルディング
cab1
1
210
Other Decks in Technology
See All in Technology
こんなところでも(地味に)活躍するImage Modeさんを知ってるかい?- Image Mode for OpenShift -
tsukaman
1
170
私たち準委任PdEは2つのプロダクトに挑戦する ~ソフトウェア、開発支援という”二重”のプロダクトエンジニアリングの実践~ / 20260212 Naoki Takahashi
shift_evolve
PRO
2
200
日本の85%が使う公共SaaSは、どう育ったのか
taketakekaho
1
240
30万人の同時アクセスに耐えたい!新サービスの盤石なリリースを支える負荷試験 / SRE Kaigi 2026
genda
4
1.4k
Why Organizations Fail: ノーベル経済学賞「国家はなぜ衰退するのか」から考えるアジャイル組織論
kawaguti
PRO
1
190
10Xにおける品質保証活動の全体像と改善 #no_more_wait_for_test
nihonbuson
PRO
2
330
制約が導く迷わない設計 〜 信頼性と運用性を両立するマイナンバー管理システムの実践 〜
bwkw
3
1k
2026年、サーバーレスの現在地 -「制約と戦う技術」から「当たり前の実行基盤」へ- /serverless2026
slsops
2
270
AIが実装する時代、人間は仕様と検証を設計する
gotalab555
1
290
ブロックテーマでサイトをリニューアルした話 / 2026-01-31 Kansai WordPress Meetup
torounit
0
480
【Ubie】AIを活用した広告アセット「爆速」生成事例 | AI_Ops_Community_Vol.2
yoshiki_0316
1
120
ファインディの横断SREがTakumi byGMOと取り組む、セキュリティと開発スピードの両立
rvirus0817
1
1.6k
Featured
See All Featured
Understanding Cognitive Biases in Performance Measurement
bluesmoon
32
2.8k
The Language of Interfaces
destraynor
162
26k
Design in an AI World
tapps
0
150
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
21
1.4k
How to Think Like a Performance Engineer
csswizardry
28
2.5k
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
62
50k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
54k
DevOps and Value Stream Thinking: Enabling flow, efficiency and business value
helenjbeal
1
110
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
350
My Coaching Mixtape
mlcsv
0
49
Optimising Largest Contentful Paint
csswizardry
37
3.6k
Dominate Local Search Results - an insider guide to GBP, reviews, and Local SEO
greggifford
PRO
0
79
Transcript
ES6࣌ͷ ؔܕϓϩάϥϛϯάೖ @Kawabata_Lemon
,BXBCBUB-FNPO ,BXBCBUB@-FNPO !,BXBCBUB@-FNPO - Lead engineer of pairs Div. eureka,
Inc. - iOS Engineer
- pairs - couples - Subsidiary of match group /
IAC
None
Agenda ‣ ؔܕͱ ‣ ؔܕ͕Θ͔Δͱ..? ‣ ͚ΕͲ෭࡞༻ͷ͜Δ ‣ ͚Ͳҙຯ͋Δ
ؔܕݴޠͱ ؔܕϓϩάϥϛϯάͰϓϩάϥϜͷߏʹؔΛଟ༻͢ΔͨΊɺ΄ ͱΜͲͷؔܕݴޠͰؔΛୈҰڃΦϒδΣΫτͱͯ͠ѻ͍ɺͦͷཧ తͳܭࢉϞσϧͱͯ͠ୈҰڃΦϒδΣΫτͱͯ͠ͷؔΛѻ͑ΔϥϜ μܭࢉ߲ॻ͖͑Λ࠾༻͍ͯ͠Δɻ 8JLJQFEJB
None
ؔܕݴޠͱ ؔܕϓϩάϥϛϯάͰϓϩάϥϜͷߏʹؔΛଟ༻͢ΔͨΊɺ΄ ͱΜͲͷؔܕݴޠͰؔΛୈҰڃΦϒδΣΫτͱͯ͠ѻ͍ɺͦͷཧ తͳܭࢉϞσϧͱͯ͠ୈҰڃΦϒδΣΫτͱͯ͠ͷؔΛѻ͑ΔϥϜ μܭࢉ߲ॻ͖͑Λ࠾༻͍ͯ͠Δɻ 8JLJQFEJB มʹؔΛ͍ΕΒΕΔ
ͲͷݴޠͰֶͿ͔ ECMASCRIPT2015
ؔܕΛֶͿͱ? ‣ ෭࡞༻͕ؾʹͳΔΑ͏ʹͳΔ ɹ-> ίϯςΩετʹΑͬͯ݁Ռ͕ҟͳΔίʔυΛආ͚Δ(lexical) ‣ ࠶ར༻ੑ͕ؾʹͳΔΑ͏ʹͳΔ -> ϓϩάϥϜͱͯ͠ͷϞδϡʔϧੑ ->
ςετ͢͠͞(Testability)
ྫ͑͜Μͳίʔυ͕
͜͏ͳΓ·͢
None
ߟ͑ํΛม͑Δ ‣ ʹରͯ͠Ͳ͏͖߹͏͔ ‣ ԿճͬͯͪΌΜͱಈ͘ͷͳͷ͔ ‣ ೖ͢Δ͜ͱ෭࡞༻ΛੜΉ
ࢀরಁաੑ in out Function ͋Δೖྗʹର͢Δग़ྗ͕ৗʹಉ͡Ͱ͋Δͱ͍͏͜ͱ ෭࡞༻͕ͳ͍ 1 2 (x) =>
x+1 ͜ͷؔৗʹ͕͑1ର1 1 2 (x) => x+1 ͳΜ͔͍͓ͬͯͳ͡ ͱͲ͏͖߹͏͔
෭࡞༻ʁ ݺͿͨͼʹ݁Ռ͕ҟͳΔ inͱout͕ৗʹಉ͡อূ͕ͳ͍ʂ
൚༻ੑ ‣ ͍·ΘͤΔ ‣ Έཱͯͯ͑Δ in out Function in out
Function2 Կճ͑Δͷ͔
͍·ΘͤΔ ‣ Ϟδϡʔϧͱͯ͠ͷϓϩάϥϜ খ͍͞ͷΛΈ߹Θͤͯେ͖ͳͷΛ࡞Δ Ϩΰͷߟ͑ํ ->
ೖ͢Δ͜ͱ෭࡞༻ΛੜΉ ‣ ͍ͭͲ͜Ͱมߋͨ͠ͷ͔Θ͔Βͳ͘ͳΔ ‣ είʔϓ֎Ͱঢ়ଶΛ࣋ͬͨΓ….
ECMASCRIPT2015 ࣌ͰͷؔܕϓϩάϥϛϯάͰؾΛ͚ͭΔ͜ͱ ‣ มͷר্͖͛ʹࠔΒͳ͍ͨΊʹlet,constΛ͓͏ let,constʹ͢Δ͜ͱͰ ReferenceErrorΛىͤ͜Δ
ECMASCRIPT2015 ࣌ͰͷؔܕϓϩάϥϛϯάͰؾΛ͚ͭΔ͜ͱ ‣ ॻ͍ͨείʔϓ௨Γͷ࣮ߦΛͤ͞ΔͨΊʹ => Λ͓͏
ECMASCRIPT2015 ࣌ͰͷؔܕϓϩάϥϛϯάͰؾΛ͚ͭΔ͜ͱ ‣ ॻ͍ͨείʔϓ௨Γͷ࣮ߦΛͤ͞ΔͨΊʹ => Λ͓͏ ఆٛ࣌ͷthis ࣮ߦ࣌ͷthis
ECMASCRIPT2015 ࣌ͰͷؔܕϓϩάϥϛϯάͰؾΛ͚ͭΔ͜ͱ ‣ ॻ͍ͨείʔϓ௨Γͷ࣮ߦΛͤ͞ΔͨΊʹ => Λ͓͏ ఆٛ࣌ͷthis ࣮ߦ࣌ͷthis
ͦΕͰͬͺΓ෭࡞༻͖·ͱ͏ ؔܕݴޠͲͷΑ͏ʹઓ͖͔ͬͯͨ ‣ Functor, Applicative, MonadͷҙຯΛͳΜͱͳ͘ཧղ͢Δ
x f(x) g(f(x) Applicative x f(x) Functor Functor, Applicative, Monadʁ
Monad = Functor + Applicative + ػೳ(ܭࢉઓུ) ͷػೳΛͭσʔλߏ ཁૉʹؔΛదԠͰ͖Δ ͦΕΛܨ͛ΒΕΔ Λฦ͔͢ ࣍ͷॲཧΛΑ Ϳ͔ʜFUD
None
mapϞφυ Applicative(ͪΌΜͱܨ͛ΒΕΔ) Functor(ΛೋഒʹͰ͖Δ)
Ϟφυ(Monad)Λ࡞ͬͯΈΔ ‣ MayBeϞφυ,IOϞφυΛ࡞ͬͯΈΔ ‣ MayBeϞφυ -> NullՄೳੑʹରͯ͠ॲཧߦ͏͔அ͢ΔϞφυ (ଞͷݴޠͰOptional<T>ܕͱݺΕΔΑ͏ͳͭ) ‣ IOϞφυ
-> ෭࡞༻ࠐΈͷॲཧΛ෦Ͱॲཧͤ͞ΔϞφυ
MaybeϞφυ -> nullՄೳੑʹରॲ͢ΔϞφυ ‣ MaybeϞφυ in out த͕nullͩͬͨΒॲཧ͠ͳ͍ nullͰॲཧΛΒͤͳ͍ΈΛσʔλʹ͍ΕΔ த͕ೖͬͯͨΒฦͯ͠ॲཧ
in out
IOϞφυ -> ֎෦͔ΒͷใΠϯϓοτͷ෭࡞༻ʹର͢ΔϞφυ in out ॲཧΛͨͤͯߦ͏ σʔλʹى͜Γ͏Δ෭࡞༻ؚΊͯ࣋ͨͤΔ
શવΘ͔Βͳͯ͘େৎ ‣ ؔܕʹ෭࡞༻ʹରͯ͠ߦ͏͖ߟ͑ํ͕٧Ίࠐ·Ε͍ͯΔ ‣ ؔܕϓϩάϥϛϯάΛ௨ͯ͡ʹ͚ͭΑ͏ ‣ ࣮ʹϞφυΛ࠶ݱ͢Δඞཁશ͘ͳ͍(ͬͯΈ͔͚ͨͬͨͩ) ‣ ͦͯࣗ͠શવΘ͔Γ͖Εͯͳ͍
ؔܕͷߟ͑ํΛֶ΅͏ ‣ ࠶ར༻ੑɺ෭࡞༻ͷগͳ͍ίʔυͷߟ͑ํΛֶ΅͏ ‣ ण໋ͷ͍ɺ൚༻ੑͷߴ͍ϓϩμΫτ࣮ ؔܕΛֶͿՁ͋Δ
ࢀߟϦϯΫ http://www.zsoltnagy.eu/functional-programming-with-es6/ http://moduscreate.com/monad-pattern-for-functional-programming-in-es6/ http://postd.cc/functional-programming-for-javascript-people-1/ https://github.com/KawabataLemon/MonadInJavascript ൃදͰ͔ͭͬͨίʔυ
Thank you