Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Speaker Deck
PRO
Sign in
Sign up for free
nuxtjs-axios-error-handling
odanado
PRO
February 03, 2020
Programming
0
180
nuxtjs-axios-error-handling
odanado
PRO
February 03, 2020
Tweet
Share
More Decks by odanado
See All by odanado
@nestjs/bull の活用について
odanado
PRO
0
290
クラウド KMS の活用 / TOKYO BLOCKCHAIN TECH MEETUP 2022
odanado
PRO
0
410
Vue.observable で状態管理 / vue-observable-state-management
odanado
PRO
4
1.4k
ブロックチェーンアプリのトランザクションに対するデータ分析 / PyCon-JP-2019
odanado
PRO
0
250
スマートコントラクトに対する既知の攻撃とその対策 / bc.tokyo-21
odanado
PRO
0
130
最近のweb3.js事情 / bc.tokyo-19
odanado
PRO
2
370
YAPC::Tokyo 2019に スタッフ参加してみて / kichijojipm-18
odanado
PRO
1
1.9k
JavaScript + Dockerの知見 / knowledge-of-docker-in-javascript
odanado
PRO
9
52k
nuxt-i18nを使ったWebサイトの多言語化 / i18n-of-web-site-using-nuxt-i18n
odanado
PRO
1
5.6k
Other Decks in Programming
See All in Programming
tidy_rpart
bk_18
0
390
MBSD Cybersecurity Challenges 2022 最終審査会 IPFactory 発表スライド
futabato
0
830
はてなリモートインターンシップ2022 フロントエンドブートキャンプ 講義資料
hatena
0
110
Jetpack Compose 完全に理解した
mkeeda
1
420
Cloudflare Workersと状態管理
chimame
2
440
Functional Data Engineering - A Blueprint for adopting functional principles in data pipeline
vananth22
0
150
Swift Observation
shiz
3
240
ECS Service Connectでマイクロサービスを繋いでみた
xblood
0
510
MapLibre GL JS とCSSアニメーションでできること
satoshi7190
0
200
低レイヤーから始める GUI
fadis
18
9.2k
(新米)エンジニアリングマネージャーのしごと #RSGT2023
murabayashi
9
5.4k
Swift Concurrency in GoodNotes
inamiy
4
1.3k
Featured
See All Featured
What's in a price? How to price your products and services
michaelherold
233
9.7k
Three Pipe Problems
jasonvnalue
89
8.9k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
29
7.7k
The Pragmatic Product Professional
lauravandoore
21
3.4k
Happy Clients
brianwarren
90
5.8k
ParisWeb 2013: Learning to Love: Crash Course in Emotional UX Design
dotmariusz
101
6.1k
Infographics Made Easy
chrislema
235
17k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
657
120k
Done Done
chrislema
178
14k
Documentation Writing (for coders)
carmenintech
51
2.9k
Reflections from 52 weeks, 52 projects
jeffersonlam
338
18k
GraphQLとの向き合い方2022年版
quramy
20
9.8k
Transcript
@nuxtjs/axios で エラーハンドリング 1 @odan3240
タピオカLT • 初LT (2020年) :tada: 2
自己紹介 • @odan3240 • 株式会社モバイルファクトリー • 最近 ◦ AWS
周り ◦ TypeScript (frontend/backend) ◦ Vue.js 3
@nuxtjs/axios • axios ◦ JavaScript の HTTP クライアントライブラリ •
NuxtJS 向けの axios モジュール ◦ https://github.com/nuxt-community/axios-module 4
エラーハンドリングしたい • API リクエストでエラーが 発生したときにエラーページに飛ばすなどしたい ◦ 公式ドキュメントにあるサンプル ◦ レスポンスが 500
エラーだと /sorry にリダイレクト 5
リダイレクトじゃない挙動にしたい • 例えば ◦ トーストを出す ◦ ページ遷移せずエラーページを表示 • redirect
を呼び出さなければ良い? ◦ NuxtJS のエラーページが表示されてしまう ▪ 内部でエラーがハンドリングされているため ▪ https://github.com/nuxt-community/axios-module/issues/149 6
やりたいこと • 内部のエラーハンドリングをキャンセル • エラーが発生したことを NuxtJS に伝える 7
問題の切り分け • 内部のエラーハンドリングをキャンセル ◦ axios の話 • エラーが発生したことを NuxtJS
に伝える ◦ nuxtjs の話 8
エラーが発生したことを NuxtJS に伝える • NuxtJS の話 • error 関数を呼び出す ◦
https://ja.nuxtjs.org/api/context/ • Nuxt.js と axios のエラーハンドリング周りの話 ◦ https://mya-ake.com/slides/nuxt-axios-error-handling 9
内部のエラーハンドリングをキャンセル • axios でリクエストをキャンセルする方法はあるか? ◦ 「axios promise cancel response」あたりでググる ◦
https://github.com/axios/axios/issues/583 ◦ axios.interceptors.response.use で false を返せば良いっぽい 10
結論 11
まとめ • @nuxtjs/axios で独自のエラーを出す方法を紹介 • 問題を切り分けて立ち向かうの大事 ◦ モジュールの組み合わせで どんどん便利になっている時代なので
• 未解決の issue に解答を示したので 後の人が楽になったはず 12