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

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

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

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

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

0回答

872閲覧

Submit時に非同期処理を実行しつつ、HTMLformのsubmitで送信する方法

moyashi777

総合スコア0

Vue.js

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

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2021/05/19 18:14

前提・実現したいこと

(例)Railsのform_withのSubmit時、確認アラートを表示し(この時点ではページ遷移なし)、「次へ」を押すことによってページ遷移するような仕組みを作ろうとしています。
フロントはVue.jsを導入し、アラートはSweetAlertを使っています(非同期のフォームライブラリ)

発生している問題・エラーメッセージ

このフォームをを送信し遷移した後、ブラウザバックをした時に、フォームの内容がブラウザキャッシュにより残っている状態を実現したいと思っているのですが、javascript内でform.Submit()することが原因で、ブラウザキャッシュが効かない状態で困っております。
参考URL:https://liliel.hateblo.jp/entry/2020/10/27/165657

該当のソースコード

html.haml

1#root 2 = form_with url: test_path, id: 'customForm', local: true do |form| 3 = form.text_field :text 4 = form.submit '確認画面へ', '@click.prevent': 'customAlert()'
var vm = new Vue({ el: '#root', methods: { customAlert: function(e) { const form = $("#customForm");      // 何らかの処理      // ・・・ // ポップアップを出力 swal.fire({ title: '確認ポップアップです', text: '次へをクリックすると遷移します', confirmButtonText: '次へ', showCancelButton: true, cancelButtonText: 'キャンセル', }) .then((result) => { if (result.isConfirmed) { form.submit(); } else { return false; }; }); }, }

試したこと

解決の糸口として、下記が思いつきました。

① form.Submit()でなく、SubmitEvent()を発生させる
② 該当のformに、複数のSubmitボタンを配置し(片方はdisplay:none)、一つ目のクリックアクションでポップアップ表示ロジックを発火させ、同ロジック内でもう一つの非表示になっているボタンのsubmitを発火させる

①については、form.Submit()の代わりに、Rails.fireを用いることにより、SubmitEventを発生させようと試みましたが、下記エラーを解決できませんでした。

vue.js:1897 TypeError: obj.dispatchEvent is not a function at Object.Rails.fire (rails-ujs.source.js:155) at Vue.customAlert (new?id=xxxx:8342) at click (eval at createFunction (vue.js:11628), <anonymous>:3:2225) at invokeWithErrorHandling (vue.js:1863) at HTMLInputElement.invoker (vue.js:2188) at HTMLInputElement.original._wrapper (vue.js:7541)

②については、試したところできそうではありましたが、綺麗ではないのでなるべく避けたいと思っています。
これら以外に、Submit時に非同期のポップアップを表示させつつ、ブラウザキャッシュが残るような形でページ遷移する方法があれば、ぜひご教示いただきたいです。

補足情報(FW/ツールのバージョンなど)

Ruby on Rails => 5.2
Vue.js => 2.6
SweetAlert2

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問