ifステートメントをコンパイルして、応答タイプがであるかどうかを確認するか、mysqli変数を確認しようとしてSingle
いMultiple
ます。Single
次にオプションをラジオボタンとして出力する場合はMultiple
、オプションをチェックボックスとして出力します。
しかし、のifステートメント内で未定義の変数エラーを受け取ります$qandaReplyType
。この問題はどのように解決できますか?
以下のコード:
$qandaquery = "SELECT q.QuestionId, r.ReplyType
FROM Question q
LEFT JOIN Reply r ON q.ReplyId = r.ReplyId
WHERE SessionId = ?
GROUP BY q.QuestionId
ORDER BY RAND()";
$qandaqrystmt=$mysqli->prepare($qandaquery);
// get result and assign variables (prefix with db)
$qandaqrystmt->execute();
$qandaqrystmt->bind_result($qandaQuestionId,$qandaReplyType);
$arrReplyType = array();
while ($qandaqrystmt->fetch()) {
$arrReplyType[ $qandaQuestionId ] = $qandaReplyType;
}
$qandaqrystmt->close();
function ExpandOptionType($option) {
$options = explode('-', $option);
if(count($options) > 1) {
$start = array_shift($options);
$end = array_shift($options);
do {
$options[] = $start;
}while(++$start <= $end);
}
else{
$options = explode(' or ', $option);
}
if($qandaReplyType == 'Single'){
foreach($options as $indivOption) {
echo '<div class="ck-button"><label class="fixedLabelCheckbox"><input type="radio" name="options_<?php echo $key; ?>[]" id="option-' . $indivOption . '" value="' . $indivOption . '" /><span>' . $indivOption . '</span></label></div>';
}
}else if($qandaReplyType == 'Multiple'){
foreach($options as $indivOption) {
echo '<div class="ck-button"><label class="fixedLabelCheckbox"><input type="checkbox" name="options_<?php echo $key; ?>[]" id="option-' . $indivOption . '" value="' . $indivOption . '" /><span>' . $indivOption . '</span></label></div>';
}
}
}
foreach ($arrQuestionId as $key=>$question) {
echo ExpandOptionType(htmlspecialchars($arrOptionType[$key]));
}
?>