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

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

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

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

HTML

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

Q&A

解決済

1回答

2437閲覧

vue.js onsubmit="return false"していてもEnterキーでsubmitしてしまう。

mikeko0901

総合スコア227

Vue.js

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

HTML

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

0グッド

0クリップ

投稿2022/05/10 03:21

フォームで、入力ヶ所にクリックをして入力がアクティブになった状態

イメージ説明
(このような状態です)

でEnterキーを押下すると以下のコードのregist関数が実行されてしまい困っています。

<html> <body> <form method="POST" action="hearing_account.php" id="order_form" name="order_form" class="h-adr" onsubmit="return false;"> <div class="form_area"> <div class="form_column"> <label class="form_label">条件1<span class="required">必須</span></label> <div class="form_input row"> <div class="form_radio" v-for="(radio_flg_option, index) in radio_flg_options"> <label class="" :key="index"> <input class="" type="radio" :value="radio_flg_option.value" name="recording_flg" v-model="recording_flg" > {{ radio_flg_option.label }} </label> </div> </div> </div> <div class="mt_big"> 以下の入力をお願いします。★問題のInputはこちらです。 </div> <div class="form_column"> <label class="form_label">アドレス<span class="required">必須</span></label> <div v-for="(address,index) in addresses" class="ip form_column_sub"> <div class="input_num_area"> {{ index + 1 }} </div> <div class="input_address_area"> <input type="text" v-model="addresses[index]" class="form_parts" name="addresses[]" > </div> </div> <div class="ip_btn_area"> <span class=""> <button type="button" @click="addInput" class="insert_btn">追加</button> </span> <span class=""> <button type="button" @click="removeInput" class="delete_btn">削除</button> </span> </div> </div> </div> <div id="form_submit"> <button class="button center_button" @click="regist">登録</button> </div> </form> <script src="https://cdnjs.cloudflare.com/ajax/libs/axios/0.18.0/axios.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/vue@2.6.10/dist/vue.min.js"></script> <script> new Vue({ el: '#app', data: { errors: [], radio_flg_options: [ {label: 'あり', value: 1}, {label: 'なし', value: 0}, ], recording_flg: "", addresses: ['',], input_num: 1, }, watch: { }, mounted: function() { }, computed: { }, methods: { removeInput: function() { if(this.input_num > 1) { this.addresses.splice(this.input_num-1, 1); // 該当するデータを削除 this.input_num = this.input_num - 1; } }, addInput: function() { this.input_num = this.input_num + 1; if(this.input_num <= 20) { this.addresses.push(''); // 配列に1つ空データを追加する } }, regist: function(e) { //★発火してしまうのはこちらの関数です。 this.errors = []; if(this.recording_flg === "") { this.errors.push("情報1をご選択ください。"); } if(this.oft_flg === "") { this.errors.push("情報1をご選択ください。"); } if(this.out_flg === "") { this.errors.push("情報3をご選択ください。"); } //バリデーションOKの時 if(this.errors.length == 0) { document.order_form.submit(); } }, } }); </script> </body> </html>

onsubmit="return false;"
を入れいているので、ページリロード後などEnterを押下してもregist関数は発火しませんが、
入力欄をクリックしてアクティブ状態でEnterキーを押下するとregist関数が発火してしまい困っております…

アドバイスいただけますと幸いです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

多分buttonが初期値submitだからEnterに反応してるんじゃない?

html

1<button class="button center_button" @click="regist">登録</button> 23<button type='button' class="button center_button" @click="regist">登録</button>

投稿2022/05/10 05:34

sousuke

総合スコア3828

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

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

mikeko0901

2022/05/10 09:32

ありがとうございます! type='button' の記述を失念しておりました。 記述しないと初期値がsubmitなんですね…勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問