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

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

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

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

HTML

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

解決済

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

mikeko0901
mikeko0901

総合スコア176

Vue.js

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

HTML

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

1回答

0評価

0クリップ

202閲覧

投稿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関数が発火してしまい困っております…

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

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Vue.js

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

HTML

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