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>
勉強中の身になりますので、他の不具合などございましたら、ご助言頂けますと幸いです。
何卒、宜しくお願い致します。
あなたの回答
tips
プレビュー