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

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

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

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

PHP

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

Q&A

解決済

2回答

1783閲覧

yes、noチャートでどの項目でyesだったかで結果を変えたい

maruku_1_27

総合スコア4

WordPress

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

PHP

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

0グッド

0クリップ

投稿2021/12/20 23:59

お世話になっております。
この度YES、NOチャートをWordPressにて実装してみることにしました。

世間で良く出回っている「YESだったら問5に飛ぶ、NOだったら問7に飛ぶ」などといったアンカー式のチャートとは違い、
全問に答えた後、設問に対するYES&NOので結果を出力する複雑なチャートになります。

前提・実現したいこと

設問ページ

php

1Q1 果物は好き? 2Q2 野菜は好き? 3Q3 温泉は好き? 4 56 7Q1(YES) Q2(YES) Q3(YES) → 結果:赤色 8Q1(YES) Q2(YES) Q3(NO) → 結果:黄色 9Q1(YES) Q2(NO) Q3(NO) → 結果:緑色 10Q1(NO) Q2(NO) Q3(NO) → 結果:青色 11Q1(NO) Q2(YES) Q3(YES) → 結果:紫色 12Q1(YES) Q2(NO) Q3(YES) → 結果:白色

上記の形が理想のチャートになります。

すべて<form><input type="radio">~中略でYES&NOの回答をするのですが、
結果ページにてその際の分岐がどうしても下記の様に蛇足気味になってしまいます…

該当のソースコード

設問ページ

php

1<form method="get" action="<?php echo home_url('/result'); ?>"> 2 <ul> 3 <li> 4 <div class="diagnose_ttl"><span>Q1</span> 果物は好き?</div> 5 <div class="flex diagnose_select"> 6 <div><input type="radio" id="yes" data-err-txt="項目が選択されていません" required name="diagnose_1" value="yes"><label>YES</label></div> 7 <div><input type="radio" id="no" data-err-txt="項目が選択されていません" name="diagnose_1" value="no"><label>NO</label></div> 8 </div> 9 </li> 10 <li> 11 <div class="diagnose_ttl"><span>Q2</span> 野菜は好き?</div> 12 <div class="flex diagnose_select"> 13 <div><input type="radio" id="yes" data-err-txt="項目が選択されていません" required name="diagnose_2" value="yes"><label>YES</label></div> 14 <div><input type="radio" id="no" data-err-txt="項目が選択されていません" name="diagnose_2" value="no"><label>NO</label></div> 15 </div> 16 </li> 17 <li> 18 <div class="diagnose_ttl"><span>Q3</span> 温泉は好き?</div> 19 <div class="flex diagnose_select"> 20 <div><input type="radio" id="yes" data-err-txt="項目が選択されていません" required name="diagnose_3" value="yes"><label>YES</label></div> 21 <div><input type="radio" id="no" data-err-txt="項目が選択されていません" name="diagnose_3" value="no"><label>NO</label></div> 22 </div> 23 </li> 24 </ul> 25 <input type="submit" value="結果" /> 26</form>

診断結果ページ

php

1<?php 2$Q1 = $_GET['diagnose_1']; 3$Q2 = $_GET['diagnose_2']; 4$Q3 = $_GET['diagnose_3']; 5 6if ($Q1 === 'yes' && $Q2 === 'no' && $Q3 === 'no') { 7 echo 'Q1だけyes'; 8} elseif ($Q1 === 'yes' && $Q2 === 'yes' && $Q3 === 'no') { 9 echo 'Q1とQ2だけyes'; 10} elseif ($Q1 === 'yes' && $Q2 === 'yes' && $Q3 === 'yes') { 11 echo '全てyes'; 12} elseif ($Q1 === 'no' && $Q2 === 'no' && $Q3 === 'no') { 13 echo 'no'; 14} elseif ($Q1 === 'no' && $Q2 === 'yes' && $Q3 === 'yes') { 15 echo 'Q1だけno'; 16} elseif ($Q1 === 'yes' && $Q2 === 'no' && $Q3 === 'yes') { 17 echo 'Q2だけno'; 18} 19?>

上記のように設問が多くなれば多くなるほどif文での書き込みが必要になり、
現在500以上のif文を書かなければいけない状態(汗)になっております。

質問事項

そこで皆様に質問がございます。
このようなチャートに対して蛇足にならない、メンテナンス性が良い書き方などありましたらご教示頂きたく存じます。

何卒宜しくお願い致します。

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

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

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

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

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

KazuhiroHatano

2021/12/21 01:48

組み合わせの数だけ結果のバリエーションがありますか? それともいくつかの組み合わせは同じ結果を返しますか? 同じ結果を返すことがある場合、そこに法則はありますか?
guest

回答2

0

ベストアンサー

メンテナンス性が良いというのが、
問題の入れ替えや仕様変更への対応が容易
というようなことであれば

  1. リクエストから回答を取得する
  2. 回答からフラグの集合を取得する
  3. フラグの集合から結果のIDを取得する
  4. 結果のIDから結果の出力を取得する

といった処理をそれぞれ関数化するなどして
切り分けておくと良いかと思います

結果のIDから結果の出力を取得する際には
フラグの集合も渡す仕様にしておけば
動的な出力にも対応しやすくなると思います


仕様変更とか内容変更に強いわけじゃなく
誰にでもわかりやすいコードというわけでもないですが
こういうやり方もあるよという参考程度に

php

1<?php 2$resultMap=[ 3 0b111=>'赤色', 4 0b110=>'黄色', 5 0b101=>'白色', 6 0b100=>'緑色', 7 0b011=>'紫色', 8 0b010=>'?色', 9 0b001=>'?色', 10 0b000=>'青色', 11]; 12function getResutID(array $answers):int{ 13 $rtn=0; 14 foreach(range(1,3) as $i){ 15 if($answers['diagnose_'.$i]==='yes'){ 16 $rtn|=1<<(3-$i); 17 } 18 } 19 return $rtn; 20} 21 22echo $resultMap[getResutID([ 23 'diagnose_1'=>'yes', 24 'diagnose_2'=>'yes', 25 'diagnose_3'=>'yes', 26])];//赤色 27echo $resultMap[getResutID([ 28 'diagnose_1'=>'yes', 29 'diagnose_2'=>'no', 30 'diagnose_3'=>'yes', 31])];//白色 32echo $resultMap[getResutID([ 33 'diagnose_1'=>'no', 34 'diagnose_2'=>'no', 35 'diagnose_3'=>'yes', 36])];//?色

頭の中で二進数を数えられるなら
$resultMap0b111=>みたいなキーの部分を省け
かつ組み合わせの抜け漏れを防げますが
そうするとどれがどれかわからなくなるので
とりあえず$resultMapはこのぐらいが妥協点

投稿2021/12/21 04:54

編集2021/12/24 06:07
KazuhiroHatano

総合スコア7819

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

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

maruku_1_27

2021/12/24 00:21

お返事おそくなりました。 ありがとうございます! 確かにメンテナンス性と一言で言っても色々ありますね。失礼いたしました。 頂いたご説明の仕様が理解できないので、色々調べてみます(;^^) ありがとうございました。
guest

0

結果的にはすべてのパターンを書くしかないと思いますが、Q1,2,3…とネストさせる書き方がいいのではないでしょうか?主観が入っているかもしれませんが、この方が各選択肢を順に追いやすくメンテしやすく感じます。

if ($Q1 === 'yes') { echo 'Q1はyes'; if ($Q2 === 'yes') { echo 'Q2はyes'; } elseif ($Q1 === 'no') { echo '$Q2はno'; } } elseif ($Q1 === 'no') { echo 'Q1はno'; }

投稿2021/12/21 00:33

wakuwaku499

総合スコア30

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

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

maruku_1_27

2021/12/21 03:30

確かにネストもそうですね! ご教示ありがとうございます(^_^)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問