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.3k
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
25
LINE開発基盤を利用した ビジネス特化型高速アプリ開発
nori3tsu
1
290
Hasuraの本番運用に向けて
nori3tsu
0
1.3k
LINE Developer Community忘年LT大会 2022 - LINE Developers News 振り返り
nori3tsu
0
240
LIFF・LINEミニアプリでApple Pay決済
nori3tsu
0
660
AWS Cloud Native イベント向けLINEボット
nori3tsu
1
360
AWSとLINE Bot Server
nori3tsu
0
590
Nuxt.jsで作るLINEボット
nori3tsu
1
700
Other Decks in Programming
See All in Programming
バグを見つけた?それAppleに直してもらおう!
uetyo
0
180
Fibonacci Function Gallery - Part 1
philipschwarz
PRO
0
220
クリエイティブコーディングとRuby学習 / Creative Coding and Learning Ruby
chobishiba
0
3.9k
なまけものオバケたち -PHP 8.4 に入った新機能の紹介-
tanakahisateru
1
120
Mermaid x AST x 生成AI = コードとドキュメントの完全同期への道
shibuyamizuho
0
160
テストコード文化を0から作り、変化し続けた組織
kazatohiei
2
1.5k
range over funcの使い道と非同期N+1リゾルバーの夢 / about a range over func
mackee
0
110
生成AIでGitHubソースコード取得して仕様書を作成
shukob
0
480
Amazon S3 NYJavaSIG 2024-12-12
sullis
0
100
「とりあえず動く」コードはよい、「読みやすい」コードはもっとよい / Code that 'just works' is good, but code that is 'readable' is even better.
mkmk884
3
500
MCP with Cloudflare Workers
yusukebe
2
220
Keeping it Ruby: Why Your Product Needs a Ruby SDK - RubyWorld 2024
envek
0
190
Featured
See All Featured
Building an army of robots
kneath
302
44k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
28
9.1k
Gamification - CAS2011
davidbonilla
80
5.1k
Unsuck your backbone
ammeep
669
57k
How STYLIGHT went responsive
nonsquared
95
5.2k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
28
900
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
191
16k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
44
9.3k
For a Future-Friendly Web
brad_frost
175
9.4k
Bash Introduction
62gerente
608
210k
4 Signs Your Business is Dying
shpigford
181
21k
Code Review Best Practice
trishagee
65
17k
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まで︕