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
Elmについて
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
shuufei
May 15, 2020
Technology
0
260
Elmについて
Elmとは何かについて調査してまとめた資料
shuufei
May 15, 2020
Tweet
Share
More Decks by shuufei
See All by shuufei
Angular with RxJS
shuufei
0
410
OOUI(オブジェクト指向UIデザイン)
shuufei
2
830
Angularにおける状態管理
shuufei
0
47
AngularにおけるComponent分割
shuufei
0
62
Other Decks in Technology
See All in Technology
フルカイテン株式会社 エンジニア向け採用資料
fullkaiten
0
10k
Digitization部 紹介資料
sansan33
PRO
1
6.8k
変化するコーディングエージェントとの現実的な付き合い方 〜Cursor安定択説と、ツールに依存しない「資産」〜
empitsu
4
1.4k
MCPでつなぐElasticsearchとLLM - 深夜の障害対応を楽にしたい / Bridging Elasticsearch and LLMs with MCP
sashimimochi
0
160
顧客との商談議事録をみんなで読んで顧客解像度を上げよう
shibayu36
0
220
顧客の言葉を、そのまま信じない勇気
yamatai1212
1
350
生成AIを活用した音声文字起こしシステムの2つの構築パターンについて
miu_crescent
PRO
2
190
Context Engineeringの取り組み
nutslove
0
340
小さく始めるBCP ― 多プロダクト環境で始める最初の一歩
kekke_n
1
400
M&A 後の統合をどう進めるか ─ ナレッジワーク × Poetics が実践した組織とシステムの融合
kworkdev
PRO
1
430
Frontier Agents (Kiro autonomous agent / AWS Security Agent / AWS DevOps Agent) の紹介
msysh
3
170
Embedded SREの終わりを設計する 「なんとなく」から計画的な自立支援へ
sansantech
PRO
3
2.4k
Featured
See All Featured
Prompt Engineering for Job Search
mfonobong
0
160
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
730
The Power of CSS Pseudo Elements
geoffreycrofte
80
6.2k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.6k
RailsConf 2023
tenderlove
30
1.3k
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.3k
Practical Orchestrator
shlominoach
191
11k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.2k
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
340
Bash Introduction
62gerente
615
210k
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
1.8k
Jess Joyce - The Pitfalls of Following Frameworks
techseoconnect
PRO
1
64
Transcript
Elm
Elmとは
Elmとは わざわざ学ばなくてもいい言語 No.1 https://www.codementor.io/blog/worst-languages-2019-6mvbfg3w9x
Elmとは Elm は JavaScript にコンパイルできる関数型プログラミング言語です。 ウェブサイトやウェブアプリケーションを作るツールという面では React のようなプロジェクトだと言えます。 Elm はシンプルであること、簡単に使えること、高品質であることを大切にしています。
https://guide.elm-lang.jp/
Elmとは 関数型プログラミング言語 Elm は JavaScript にコンパイルできる です。 ウェブサイトやウェブアプリケーションを作るツールという面では React のようなプロジェクトだと言えます。
Elm はシンプルであること、簡単に使えること、高品質であることを大切にしています。 https://guide.elm-lang.jp/
Elmとは なぜ関数型を採用しているのか ?
Elmとは なぜ関数型を採用しているのか ? ・実用上ランタイムエラーがでないし、nullもないし、 undefinedが関数だなんて話はあえません。 ・とてもわかりやすい親切なエラーメッセージによって より素早くあなたのコードに機能を追加できます。 ・コードの規模が大きくなっても全体の設計が壊れることがありません。
・すべてのElmパッケージにおいて、決められたルールに則って 自動的にバージョン番号が付与されています。 https://guide.elm-lang.jp/
Elmとは 他の人の声 Elmはアンチパターンを実装できない。 人の目を介さず、人的リソースを使わずにソフトウェア品質の最低ラインを 強力な形で担保できる。 https://qiita.com/lambda_funtaro/items/2d4d82412d0bb7179cf3
Elmとは ・困った時にコンパイラが助けてくれます。エラーメッセージがわかりやくて便利です。 コンパイラと型システムのおかげでElmでは普通、実行時例外 (runtime exception)が 起こりません。 ・リファクタリングが簡単で、コンパイルが通ればまた正確に動きます。
最初に書くときもそれが多いです。コンパイルで問題がなければバグが 驚くほど少ないです。 ・テストしやすい。純粋(つまり副作用がない)関数でテストしやすく、 Elmアーキテクチャーならアプリの状態が簡単に再現できます。 https://nulab.com/ja/blog/typetalk/elm-introduction-tutorial 他の人の声
Elmとは 強めの制約がある状態で開発を行うことで、 より安全に、より保守しやすい状態で開発していくことができそう。
関数型プログラミングとは
関数型プログラミングとは 関数プログラミングにおける関数
関数プログラミングにおける関数 関数プログラミング実践入門 命令型言語 特定の命令/手続きの列に付けられたラベル 関数プログラミング 「与えられた入力の値のみから出力となる値をただ1つ決める規則」 という数学的な意味 関数型プログラミングとは
関数プログラミングにおける関数 関数プログラミング実践入門 関数型プログラミングとは
関数プログラミングにおける関数 関数プログラミング実践入門 命令型言語 特定の命令/手続きの列に付けられたラベル という数学的な意味 「与えられた入力の値のみから出力となる値をただ1つ決める規則」 この性質を参照透過性という。 参照透過性をもつ関数を純粋関数という。 関数型プログラミングとは
関数プログラミングにおける関数 関数プログラミング実践入門 関数型プログラミングとは
副作用 関数型プログラミングとは
副作用 関数プログラミング実践入門 状態を参照し、あるいは状態に変化を与えることで、 次回以降の結果にまで影響を与える効果のことを副作用と呼ぶ。 副作用をもつ手続きは、前述した 「関数」 ではない。 関数型プログラミングとは
関数プログラミング実践入門 関数型プログラミングとは 副作用
関数が副作用のない純粋関数であることで、 テストのしやすさや、モジュラリティが向上する。 関数型プログラミングでは、 モジュラリティを活かし、関数を組み合わせて新たな合成関数を定義したり、 それらの関数を使って、求めたい結果の性質を宣言する形でプログラミングする。 関数型プログラミングとは 関数プログラミング実践入門
関数型プログラミング言語
関数型プログラミングを実践することに特化した言語 (?) 関数型プログラミング言語
関数型プログラミング言語 関数型プログラミング言語の特徴
関数型プログラミング言語 関数プログラミング実践入門 言語使用で定義されていない動作を発生させないことを、安全性という。 型検査に成功すれば安全性が保証される型付けを強い型付けという。 ・強い型付け 型検査をコンパイル時に行うのが静的型付け、ランタイムに行うのが動的型付け。 ・静的型付け 参照透過性という性質を持っているということ。 ・純粋 与えられた型の情報から、与えられていない部分の方も推論してくれる機能。
・型推論 関数型プログラミング言語の特徴
なんだかランタイムでのエラーが起きにくそうな特徴 関数型プログラミング言語 関数型プログラミング言語の特徴
より安全に、より保守しやすい状態で開発する (ということでいいかもしれない) Elmをやるモチベーション
Elmアーキテクチャ
https://guide.elm-lang.jp/architecture/ Elmアーキテクチャ
Elmでアプリケーションを開発する
Elmでアプリケーションを開発する 1つのjsファイルにバンドルし、index.htmlで読み込む。 1 1 2 初期化処理 2 https://guide.elm-lang.jp/webapps/
Elmでアプリケーションを開発する https://guide.elm-lang.jp/interop/ports.html JSのエコシステムと組み合わせる場合は、ポートという機能を利用し、 相互でメッセージのやりとりを行う。 Javascript Elm subscribe send
Elmでアプリケーションを開発する https://guide.elm-lang.jp/interop/ports.html JavascriptでElmからのメッセージを受け取る
Elmでアプリケーションを開発する https://guide.elm-lang.jp/interop/ports.html JavascriptからElmにメッセージを送る
まとめ
まとめ より安全に、より保守しやすい状態で開発していきたい場合はElm良さそう。 関数型プログラミング好きな人には良さそう。 個人的には、がっつりやるモチベーションはまだ生まれなかった。 関数型プログラミングは面白いとよく聞くので、まずそこから学んでみたい。
Elm