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

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

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

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

HTML

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

Q&A

解決済

3回答

1710閲覧

問い合わせフォーム ”required”について

Kojiy

総合スコア1

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

HTML

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

0グッド

0クリップ

投稿2020/08/26 01:26

前提・実現したいこと

書籍やネットの情報でホームページを自作しております。
問い合わせ欄にて、フォーム入力情報がPHPでメール送信させています。

入力中にエンターキーで誤送信されてくることが多く、
「onsubmit="return false」「<input type="button" value="送信" onclick="submit();">
とすることで解消しましたが、

今度は、「required」が効かなくなってしまいました。

初歩的なことかと思いますが、
入力中のエンターキーによる送信を無効にしつつ、
必須項目に対して「required」にて必須とするにはどのようにすればよいのでしょうか・・・?

該当のソースコード

<form action="checks-output.php" method="post" onsubmit="return false;">  ... <dt>会社名</dt> <dd><input type="text" name="companyname" class="name" required></dd> <dt>お名前</dt> <dd><input type="text" name="name" class="name" required></dd> <dt>お問い合わせ内容</dt> <dd><textarea name="message" class="message"></textarea></dd>  ... <input type="button" value="送信" onclick="submit();"> </form>

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

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

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

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

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

guest

回答3

0

フォームの入力チェックをjsで行う事例:
送信フォームの入力必須項目が入力されているかチェックするJavaScriptサンプル

jsでフォーム送信を検査してから送信して、
受信するphp側でももう一度検査するのがよろしいかと。
(いたずらしようと思えば、いくらでもいたずらできてしまうので。)

投稿2020/08/26 03:22

編集2020/08/26 03:26
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

Kojiy

2020/08/26 04:12

ありがとうございます。yambejpさんの回答にて実現できました。
guest

0

いっそ必須チェックはJavaScriptとPHPでされては。

投稿2020/08/26 01:34

m.ts10806

総合スコア80875

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

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

0

ベストアンサー

普通はエンターキーを無効にするjsを書くのですが
反応するのは最初のサブミットなので無理やりこうする手もあります

投稿2020/08/26 01:36

yambejp

総合スコア116724

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

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

yambejp

2020/08/26 01:36

<form > <dt>会社名</dt> <dd><input type="text" name="companyname" class="name" required></dd> <dt>お名前</dt> <dd><input type="text" name="name" class="name" required></dd> <dt>お問い合わせ内容</dt> <dd><textarea name="message" class="message"></textarea></dd> <input type="submit" style="position:absolute;top:-999px" onclick="return false"> <input type="submit" value="送信"> </form>
yambejp

2020/08/26 01:38

モダンなブラウザならdisplay:noneとdisabledでいけそうですけどね <input type="submit" style="display:none" disabled>
Kojiy

2020/08/26 04:11

こちらで実現できました!ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問