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
Vue.js-Nuxt.jsのグローバルエラーハンドリング実装.pdf
Search
Norimitsu Yamashita
October 10, 2019
Programming
1
4.2k
Vue.js-Nuxt.jsのグローバルエラーハンドリング実装.pdf
Norimitsu Yamashita
October 10, 2019
Tweet
Share
More Decks by Norimitsu Yamashita
See All by Norimitsu Yamashita
セキュアに実装するLINEログイン
nori3tsu
0
23
LINE開発基盤を利用した ビジネス特化型高速アプリ開発
nori3tsu
1
280
Hasuraの本番運用に向けて
nori3tsu
0
1.2k
LINE Developer Community忘年LT大会 2022 - LINE Developers News 振り返り
nori3tsu
0
230
LIFF・LINEミニアプリでApple Pay決済
nori3tsu
0
650
AWS Cloud Native イベント向けLINEボット
nori3tsu
1
350
AWSとLINE Bot Server
nori3tsu
0
580
Nuxt.jsで作るLINEボット
nori3tsu
1
690
Other Decks in Programming
See All in Programming
Pinia Colada が実現するスマートな非同期処理
naokihaba
4
230
3rd party scriptでもReactを使いたい! Preact + Reactのハイブリッド開発
righttouch
PRO
1
600
Make Impossible States Impossibleを 意識してReactのPropsを設計しよう
ikumatadokoro
0
180
카카오페이는 어떻게 수천만 결제를 처리할까? 우아한 결제 분산락 노하우
kakao
PRO
0
110
Flutterを言い訳にしない!アプリの使い心地改善テクニック5選🔥
kno3a87
1
190
Click-free releases & the making of a CLI app
oheyadam
2
120
Nurturing OpenJDK distribution: Eclipse Temurin Success History and plan
ivargrimstad
0
940
リアーキテクチャxDDD 1年間の取り組みと進化
hsawaji
1
220
ECS Service Connectのこれまでのアップデートと今後のRoadmapを見てみる
tkikuc
2
250
subpath importsで始めるモック生活
10tera
0
310
CSC509 Lecture 11
javiergs
PRO
0
180
LLM生成文章の精度評価自動化とプロンプトチューニングの効率化について
layerx
PRO
2
190
Featured
See All Featured
Building an army of robots
kneath
302
43k
Six Lessons from altMBA
skipperchong
27
3.5k
Rebuilding a faster, lazier Slack
samanthasiow
79
8.7k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
6
410
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
226
22k
Code Review Best Practice
trishagee
64
17k
Art, The Web, and Tiny UX
lynnandtonic
297
20k
The Cult of Friendly URLs
andyhume
78
6k
The Illustrated Children's Guide to Kubernetes
chrisshort
48
48k
What’s in a name? Adding method to the madness
productmarketing
PRO
22
3.1k
Learning to Love Humans: Emotional Interface Design
aarron
273
40k
Making the Leap to Tech Lead
cromwellryan
133
8.9k
Transcript
Copyright ©2019 Grandream Inc. All Rights Reserved. Meguro.es # 23
@ Wantedly, Inc. Vue.js / Nuxt.js の グローバルエラーハンドリング実装
- 2 - Copyright ©2019 Grandream Inc. All Rights Reserved.
⾃⼰紹介 @nori3tsu ⼭下 徳光 / Norimitsu Yamashita ⽬⿊⻄⼝にある 株式会社グランドリーム という会社をやってます。 SPA/PWA+AWSサーバーレスを活⽤したアプリ開発が得意です。 最近は、クライアント/サーバーのコードにTypeScriptを使ってい ます。 norimitsu.yamashita nori3tsu
- 3 - Copyright ©2019 Grandream Inc. All Rights Reserved.
1, メソッド定義のエラーハンドリングの課題 2, 課題1の解決⽅法 – カスタムエラークラス 4, 課題2の解決⽅法 – グローバルエラーハンドリング 5, Vue.js / Nuxt.js に組み込む 6, まとめ
- 4 - Copyright ©2019 Grandream Inc. All Rights Reserved.
1, メソッド定義のエラーハンドリングの課題
- 5 - Copyright ©2019 Grandream Inc. All Rights Reserved.
1, メソッド定義のエラーハンドリングの課題 メソッド内に定義されたエラーハンドリング:
- 6 - Copyright ©2019 Grandream Inc. All Rights Reserved.
1, メソッド定義のエラーハンドリングの課題 課題1: エラー判定処理が散らばる マジックナンバー、可読性が悪い
- 7 - Copyright ©2019 Grandream Inc. All Rights Reserved.
1, メソッド定義のエラーハンドリングの課題 課題2: エラーハンドリング後の処理が散らばる 様々な場所に同じ業務処理があると、 コードの変更に弱くなる。
- 8 - Copyright ©2019 Grandream Inc. All Rights Reserved.
1, メソッド定義のエラーハンドリングの課題 • 課題1: エラー判定処理が散らばる • -> カスタムエラークラスの作成 • 課題2: エラーハンドリング後の処理が散らばる • -> グローバルエラーハンドリング
- 9 - Copyright ©2019 Grandream Inc. All Rights Reserved.
1, メソッド定義のエラーハンドリングの課題 Before: メソッド内に定義されたエラーハンドリングが…
- 10 - Copyright ©2019 Grandream Inc. All Rights Reserved.
1, メソッド定義のエラーハンドリングの課題 After: グローバルエラーハンドリングでスッキリ︕︕
- 11 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装
- 12 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 課題1: エラー判定処理が散らばる
- 13 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 Web API 通信処理を例にとって説明します。
- 14 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 Web API 通信処理で発⽣するエラーは どんなものがあるでしょうか︖ HTTPステータスコード
- 15 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 HTTPステータスコードは、HTTPにおいて Webサーバからのレスポンスの意味を表現す る3桁の数字からなるコードである。 Wikipedia
- 16 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 異常系 HTTPステータスの分類 • クライアントエラー • 400 Bad Request(⼊⼒値不正エラー) • 401 Unauthorized(認証エラー) • 403 Forbidden(アクセス権限エラー) • 404 Not Found(NotFoundエラー) • 409 Conflict(競合エラー)
- 17 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 • サーバーエラー • 500 Internal Server Error(内部システム エラー) • 503 Service Unavailable(サービス利⽤不 可エラー)
- 18 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 Web API 通信処理のカスタムエラークラスの実装 https://github.com/necojackarc/extensible-custom-error
- 19 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 Web API 通信処理のエラー処理を拡張
- 20 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 Before: マジックナンバーの判定処理が…
- 21 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 After: エラークラスの判定に︕
- 22 - Copyright ©2019 Grandream Inc. All Rights Reserved.
3, 課題2の解決⽅法 – グローバルエラーハン ドリング
- 23 - Copyright ©2019 Grandream Inc. All Rights Reserved.
2, 課題1の解決⽅法 – カスタムエラークラスの実装 課題2: エラーハンドリング後の処理が散らばる
- 24 - Copyright ©2019 Grandream Inc. All Rights Reserved.
3, 課題2の解決⽅法 – グローバルエラーハンドリング Vue.js で発⽣するエラーのハンドリング⽅法 1. Vue.js 内で発⽣したエラー • data, computed, methods 等 2. Vue.js 外で発⽣したエラー • インスタンス変数の初期化 等 3. Promise.rejected エラー • ⾮同期処理エラーのキャッチ漏れ
- 25 - Copyright ©2019 Grandream Inc. All Rights Reserved.
3, 課題2の解決⽅法 – グローバルエラーハンドリング 具体的なハンドリング⽅法
- 26 - Copyright ©2019 Grandream Inc. All Rights Reserved.
3, 課題2の解決⽅法 – グローバルエラーハンドリング Vue.jsのグローバルエラーハンドリングとは…︖ Vue.jsで発⽣する 3パターンのエラーを処理する 共通関数処理のこと。
- 27 - Copyright ©2019 Grandream Inc. All Rights Reserved.
3, 課題2の解決⽅法 – グローバルエラーハンドリング エラー処理の共通関数を⽤意して
- 28 - Copyright ©2019 Grandream Inc. All Rights Reserved.
3, 課題2の解決⽅法 – グローバルエラーハンドリング 各種エラーハンドラーで呼び出す = グローバルエラーハンドリング
- 29 - Copyright ©2019 Grandream Inc. All Rights Reserved.
4, Vue.js / Nuxt.js に組み込む
- 30 - Copyright ©2019 Grandream Inc. All Rights Reserved.
4, Vue.js / Nuxt.js に組み込む Vue.js に組み込む:
- 31 - Copyright ©2019 Grandream Inc. All Rights Reserved.
4, Vue.js / Nuxt.js に組み込む Nuxt.jsに組み込む: ~plugins/error-handler.js
- 32 - Copyright ©2019 Grandream Inc. All Rights Reserved.
5, まとめ
- 33 - Copyright ©2019 Grandream Inc. All Rights Reserved.
5, まとめ • グローバルエラーハンドリング • 可読性・メンテナンス性の向上 • Vue.js / Nuxt.js では Plugins を利⽤
- 34 - Copyright ©2019 Grandream Inc. All Rights Reserved.
さいごに… • ⼀緒に働いてくれるエンジニア仲間 • 下記の技術を使ったお仕事 • TypeScript • Vue.js / Nuxt.js • SPA / PWA / BFF / API • AWSサーバーレス ⼤募集中︕︕
- 35 - Copyright ©2019 Grandream Inc. All Rights Reserved.
ご清聴 ありがとうございました 開発のご相談はHPまで︕