質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

Q&A

解決済

1回答

2603閲覧

Nuxtでページの初回アクセス時にFetchやAsync Dataフックの結果が取得できない

nieve

総合スコア33

Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

0グッド

0クリップ

投稿2021/04/27 11:18

Nuxt.jsにてPageのコンポーネントでaxiosを使ってデータを取得しようとしています。

[page/index.vue] <script> export default { name: 'HomePage', data() { return { somedata: {} } }, async asyncData({ $axios, params }) { console.log('asyncData') }, async fetch({ $axios, params }) { console.log('fetch') this.somedata= await $axios.$get('http://localhost:53054/api/index'); console.log(this.spotifyData) } } </script>

※ちなみに、
http://localhost:53054/api/index は同一Nuxt appの中にserverMiddlewareをたてて作成したExpress appで、
responseを返す直前にconsole.log(response)してます。

すると結果、クライアント側のconsoleは↓になり、クライアントサイドの結果はありません。
axiosfetch asyncDataどちらに書いても同じです。

Nuxt SSR  asyncData fetch {Expressのresponseの中身}

しかし、ここで

  • ページ遷移を行いその後indexページに再度(リロードすることなく)アクセスする
  • [page/index.vue]を上書き保存

のどちらかを行うと、console(クライアント側)は↓になります。

Nuxt SSR  asyncData fetch {Expressのresponseの中身} (※↑ここまではさっきのアクセスによる結果表示↑※) asyncData fetch {axiosで取得した結果}

都合上、axiosbaseURLを別URLに向けてるせい?
とも思ったのですが、
設定を外したり、今回のapiのものにするとNuxt appがそもそも起動せずで…
(baseURLを利用した他のURLにbaseURLの同一中身を直記入しても同じく起動せず…)

SSRとaxiosの設定の相性が悪いのでしょうか?
どうしたら初回アクセスからデータが取得できますでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

質問の内容がおかしかったです。

フロー的にSSRで取得されるので、それはあってました。

templateに取得した内容を利用しようとするとエラーになったので、
書き換えたり質問させていただいたのですが。。。

改めて
asyncData 側に axiosを書き直したらtemplate内に取得した内容を利用できました。

お騒がせいたしました。

投稿2021/04/27 14:09

nieve

総合スコア33

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問