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

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

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

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

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

Q&A

0回答

3526閲覧

【WordPress】MW WP Formの選択肢による必須切替

ccccc

総合スコア10

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

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

0グッド

1クリップ

投稿2019/01/06 10:48

編集2022/01/12 10:55

MW WP Form を使用し、募集内容のフォームを作成していたら、突き当たりました。
どうかお力添え頂けませんでしょうか。

###記入の有無
ラジオボタンで有りの場合 → テキストエリアにて、必須をつけたテキストの入力を促す。
まではできているのですが・・・
【有り】の場合、テキストエリアを表示、なおかつテキストエリアに必須項目をつける。
【無し】の場合、【有り】を選択しテキストに入力していたものをクリア(入力していない状態に戻す)にしたいです。

###ラジオボタン三択からの選択に必須をつけたい
【選択肢A】  【選択肢B】  【選択肢C】
.   ↓       ↓       ↓
【リストA】  【リストB】   【リストCとD】

【選択肢A】を選択している場合、【リストA】を表示、【リストB】と【リストCとD】は非表示。<div class="pickup-op">
【選択肢B】を選択している場合、【リストB】を表示、【リストA】と【リストCとD】は非表示。<div class="pickup-op2">
【選択肢C】を選択している場合、【リストCとD】を表示、【リストA】と【リストB】は非表示。<div class="pickup-op3">

【リストB~D】を選択したら、【リストA】の入力を初期値に戻す。
以上の手順を同じように繰り返すまでは、なんとかできましたが・・・

【リストA~D】をバリデーションで必須をつけると、お互いが邪魔をしてメールの送信が行えません。
【選択肢A】選択→【リストA】表示し選択→**【リストB】と【リストCとD】は非表示にし、なおかつ必須をはずす**ことは可能でしょうか?

MW WP Form

html

1<table> 2<tr> 3<td>記入の有無</td> 4<td> 5[mwform_error keys="記入の有無"] 6[mwform_radio name="記入の有無" children="有り,:無し" show_error="false"] 7[mwform_error keys="記入有りの場合"] 8[mwform_text name="記入有りの場合" size="30" maxlength="255" show_error="false" placeholder="ここに入力してください"] 9</td> 10</tr> 11 12<tr> 13<td>サークル傾向</td> 14<td> 15[mwform_radio name="大元の選択肢" id="pickup" value="1" children="1:選択肢A,2:選択肢B,3:選択肢C"] 16<div class="pickup-op"> 17[mwform_select name="リストA" children=":選んでください,A,B,C" post_raw="true"] 18</div> 19<div class="pickup-op2"> 20[mwform_select name="リストB" children=":選んでください,A,B,C" post_raw="true"] 21</div> 22<div class="pickup-op3"> 231:[mwform_select name="リストC" children=":選んでください,A,B,C" post_raw="true"] 242:[mwform_select name="リストD" children=":選んでください,A,B,C" post_raw="true"] 25</div> 26</td> 27</tr> 28</table> 29

functions.php

//記入の有無 function my_validation_rule( $Validation, $data ) { if ( $data['記入の有無'] === '有り' ) { $Validation->set_rule( '記入有りの場合', 'noEmpty', array( 'message' => 'テキストを入力してください' ) ); } return $Validation; } add_filter( 'mwform_validation_mw-wp-form-xxx', 'my_validation_rule', 10, 2 );

header.php

<script> //入力ボックスの開閉 $(function() { $('[name="大元の選択肢"]:radio').change(function() {  $(".pickup-op").hide() if ($("input:radio[name='大元の選択肢']:checked").val() == "1") {   $('.pickup-op').show(); } else if($("input:radio[name='大元の選択肢']:checked").val() == "2") {   $("select[name='リストA']").val(""); } else if($("input:radio[name='大元の選択肢']:checked").val() == "3") {   $("select[name='リストA']").val(""); } }).trigger('change'); }); </script> <script> //入力ボックスの開閉 2 $(function() { $('[name="大元の選択肢"]:radio').change(function() {  $(".pickup-op2").hide();  if ($("input:radio[name='大元の選択肢']:checked").val() == "2") {   $('.pickup-op2').show(); } else if($("input:radio[name='大元の選択肢']:checked").val() == "1") {   $("select[name='リストB']").val(""); } else if($("input:radio[name='大元の選択肢']:checked").val() == "3") {   $("select[name='リストB']").val(""); } }).trigger('change'); }); </script> <script> //入力ボックスの開閉 3 $(function() { $('[name="大元の選択肢"]:radio').change(function() {  $(".pickup-op3").hide();  if ($("input:radio[name='大元の選択肢']:checked").val() == "3") {   $('.pickup-op3').show(); } else if($("input:radio[name='大元の選択肢']:checked").val() == "1") {   $("select[name='リストC']").val("");   $("select[name='リストD']").val(""); } else if($("input:radio[name='大元の選択肢']:checked").val() == "2") {   $("select[name='リストC']").val("");   $("select[name='リストD']").val(""); } }).trigger('change'); }); </script>

勉強中の身になりますので、他の不具合などございましたら、ご助言頂けますと幸いです。
何卒、宜しくお願い致します。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問