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
僕のフロントエンド奮闘記コンポーネントで、すったもんだ
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
nao-bt
February 24, 2018
Programming
1.1k
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
僕のフロントエンド奮闘記コンポーネントで、すったもんだ
We Are JavaScripters! @16th【初心者歓迎LT大会】の資料です。
https://wajs.connpass.com/event/78939/
nao-bt
February 24, 2018
More Decks by nao-bt
See All by nao-bt
そろそろWebpackと真剣に向き合ってみる
naotobt
9
5.1k
Other Decks in Programming
See All in Programming
[2026年度第1回ORセミナー] 計画最適化ベンチャーと競技プログラミング人材
terryu16
0
250
AutonomyとControlのあいだ:Graflowで記述するAIエージェント協調
myui
0
110
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
5k
JJUG CCC 2026 Spring: JSpecify で実現する Kotlin フレンドリーな Java API 設計
ternbusty
1
160
Observability in Practice:Grafana 與 Edge Device SRE 的那些事
blueswen
0
150
Claspは野良GASの夢をみるか
takter00
0
180
Vue × Nuxt × Oxc どこまで使える?実運用の現在地
andpad
0
130
過去最大のMCPアップデート! 2026-07-28 RC版の謎に迫る
licux
6
210
Copilot CLI の継戦能力を高める コンテキスト管理
nozomutu
1
1.2k
Signal Forms: Beyond the Basics @ngBaguette 2026 in Paris
manfredsteyer
PRO
0
230
脅威をエンジニアリングの糧にして――現場編 / Turning Threats into Engineering Fuel — Field Edition
nrslib
0
270
さぁV100、メモリをお食べ・・・
nilpe
0
130
Featured
See All Featured
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
38
2.9k
How to Grow Your eCommerce with AI & Automation
katarinadahlin
PRO
1
200
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
440
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
71
40k
Designing for Timeless Needs
cassininazir
1
250
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
170
Large-scale JavaScript Application Architecture
addyosmani
515
110k
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
YesSQL, Process and Tooling at Scale
rocio
174
15k
30 Presentation Tips
portentint
PRO
1
320
State of Search Keynote: SEO is Dead Long Live SEO
ryanjones
0
200
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
220
Transcript
僕のフロントエンド奮闘記 コンポーネントで、すったもんだ Nao-bt
自己紹介 文系出身・プログラミング歴は約5年目。 サーバーもフロントもやる人。 ※できるとは言っていない。日々勉強中。 JSに関しては 前の会社でAngularJsの1.4系を業務で利用。 徐々にJSの面白みを感じ、個人的にフレームワークを中心に 勉強しはじめる。 いまの会社では レガシーでローカル開発環境のない基幹システムを
Vueを利用してリプレースしてます(主にフロント担当)。
今日は、コンポーネントで すったもんだした話。
JSフレームワークを使った開発を これから始める人に参考になれば・・・。
コンポーネント指向って? 画面をUIパーツごとに 分割して作り、組み合わせる。 パーツごとに作るから、 再利用しやすく 分業やテストがしやすい。
コンポーネント間のやりとり props down(親→子), events up(子→親)
親 子 親は子が どんなプロパティを受け取り どんなイベントを返すかを知っている。 子は親を知らなくてもいい。 コンポーネントの階層が深くなれば バケツリレーのようにしていく。
親は子を必ず知っているが、 子は親を知らなくてもいい。 再利用可能なコンポーネントの肝
JSフレームワークを使うと コンポーネント指向に基づく 開発ができる
でも どんなふうに どれくらいの細かさで コンポーネントって区切るんだ??
サーバーサイドのMVCみたいな 目安になるような分け方の 基準はないのかなぁ
そんなときに巡り合ったのが・・・
Atomic Design
コンポーネントの単位を5つの大きさに分けて作る考え方。 Atoms(原子) Molecules(分子) Organisms(有機体) Templates(テンプレート) Pages(ページ)
引用元:http://atomicdesign.bradfrost.com/chapter-2/
なんとなくよさげだ これでいってみよう。
Vuexも使ってみよう
Vuexを使うことで アプリの状態(データや storeとよばれることも)を コンポーネントから分離することができる。 親子関係のないコンポーネント間でも 状態の表示や変更が可能。 わざわざバケツリレーを書かなくてもよくなる。 Vuex公式サイトより、 Vuex を使った最も基本的なカウンターアプリの例
バケツリレーしなくていいなんて 素敵! 実装がはかどる!!
そう、このとき、 私は浮かれていました・・・。
バケツリレーの代わりにコンポーネント内に Vuex用の記載が増えていった。 ※実際のソースは見せれないので Vuex公式のサンプルより
どんなAction、Mutationがあるかを知らないと 成立しないコンポーネントを大量生産
Vuexと蜜結合で再利用できない
Atomic Designの振り返り ・これ再利用するかな?って場合が多々ある。 ・回数制限を設けて、既定の回数同じのを書いたら、 コンポーネント化するとかもありでは? ・初期は大変だろうけど、どんどん開発が進むにつ入れて楽になる。 ・一般ユーザー向けの場合は、見栄えとか重要だから 同じようなコンポーネントがたくさんできそう。
・Pagesコンポーネントの階層に Vuexをまとめて、そこから下の階層に バケツリレーすべきだった。 ・でも急いで実装しないといけない時は Vuexは助かる。(でも麻薬だと思う) Vuexとの組み合わせについての振り返り
よく考えて実装しないと 大変なことになる・・・。 他の人達がどんな コンポーネント管理してるか気になる! 懇親会で 教えてください・・・。