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

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

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

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Laravel 6

Laravel 6は、オープンソースなPHPのフレームワーク。Webアプリケーションの開発に適しており、バージョン6はLTSです。5.8での向上に加えて、セマンティックバージョニングの採用やLaravel Vaporとのコンパチビリティなどが変更されています。

Q&A

0回答

753閲覧

リダイレクト後に再度getするような処理って可能なのでしょうか? Laravel Vue3

tkm0604

総合スコア554

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Laravel 6

Laravel 6は、オープンソースなPHPのフレームワーク。Webアプリケーションの開発に適しており、バージョン6はLTSです。5.8での向上に加えて、セマンティックバージョニングの採用やLaravel Vaporとのコンパチビリティなどが変更されています。

0グッド

1クリップ

投稿2022/05/23 09:32

バックエンドをLaravel6 フロントをVue3にて作成しています。

リダイレクト後に再度getするような処理って可能なのでしょうか?

[実現したい動作]
1.vue コンポーネントで作成した投稿をaxios経由でLaravel DBへPOST
2.axios経由で送られてきた情報をLaravel DBへ保存
3.api コントローラーから投稿の表示ページへリダイレクト
4.投稿の表示ページで最新の投稿を1件表示

[問題点]
「4.投稿の表示ページで最新の投稿を1件表示」の際に1件前の投稿が表示され、画面をリロードすると最新の投稿が表示されます。

vue側の処理を色々疑ったのですが、解決に至っておらず、リダイレクト後に再度getするような処理が実現できれば解決できるのか?と考えています。

しかしその方法がわかりません。。。。

apiからのリクエスト処理は以下の様に書いています。

api.php

1Route::post('api/images', 'ImageApiController@redirect');

apiController

1 //ImageApiControllerからリダイレクトで送られてきた情報をshow.blade.phpに渡し、リターンする処理 2 public function redirect(Image $image) 3 { 4 $user = auth()->user(); 5 $image = Image::where('user_id', $user->id)->orderBy('created_at', 'desc')->first(); 6 return view('show', compact('user', 'image')); 7 }

apiからのリダイレクトを受け取り表示する処理

HomeController.php

1 //ImageApiControllerからリダイレクトで送られてきた情報をshow.blade.phpに渡し、リターンする処理 2 public function redirect(Image $image) 3 { 4 $user = auth()->user(); 5 $image = Image::where('user_id', $user->id)->orderBy('created_at', 'desc')->first(); 6 return view('show', compact('user', 'image')); 7 }

web.php

1Route::get('show','HomeController@redirect');

リダイレクト先で前回のgetデータをそのまま取得しているから、1件前の投稿が表示されているのだと考えています。
であれば、リダイレクト先で再度GETを行えば解決できるのでは?と思うのですが、そんな方法はあるのでしょうか?

方法を検索するワードでも構いません。
リダイレクト後に再度getするような処理を教えてください。

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

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

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

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

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

hoshi-takanori

2022/05/23 10:11

Vue 側は、いわゆる SPA ではないのですか? axios で結果を受け取って、そのまま vue で表示内容を更新すれば良いのでは…。
tkm0604

2022/05/23 10:39

Vue側はいわゆるSPAです。 Laravel以上にVue側の知識に疎く、おっしゃられる、「 axios で結果を受け取って、そのまま vue で表示内容を更新」というのはどの様な処理でしょうか? Vue側で遷移先ページを指定する処理を行う。 という事でしょうか? その場合、Vue-routerを使う方法でいいでしょうか? vue側のaxiosでPOSTするコードは以下の様に書いています。 //new FormData() を作成 const data = new FormData(); data.append("canvas", blob, "png"); data.append("title", title.value); data.append("comment", comment.value); axios .post("/api/images", data) .then((res) => { console.log("success"); }) .catch((error) => { new Error(error); });
hoshi-takanori

2022/05/23 10:50

SPA ということは、実際にはページ遷移せずに表示内容を JavaScript で書き換えて、ブラウザの履歴に細工をして URL が切り替わったように見せます。ので、リダイレクトもしません。 Vue は詳しくないので具体的なやり方は知りませんが、たぶんこのへんが参考になるのでは。 https://qiita.com/ksh-fthr/items/a4ac1d04d9923c550cd7
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問