前提・実現したいこと
入力値を判定して、文字列で表示をしたい。
<input type="radio" name="difficulty" value="1">簡単
<input type="radio" name="difficulty" value="2" checked>普通
<input type="radio" name="difficulty" value="3">難しい
入力フォームからこれで入力しています。
データーベースには、上手くつながってます。
ただ、ブラウザ画面で表示されるのが、valueの数字の値になります。
「簡単、普通、難しい」といった文字列で表示したいのですが、どんなコードが考えられますか?
if文で、条件判定してやればいいかと思うんですが、内容が良くわかりません。
どなたかご教授願います。
~以下追記~
ブラウザは、chromeです。MAMPを使っています。
~以下追加2~
ちなみに市販のテキストを写し、自分で内容を変更しようとしています。
HTMLのform部分です
<form method="post" action="add.php"> 難易度: <input type="radio" name="difficulty" value="1">簡単 <input type="radio" name="difficulty" value="2" checked>普通 <input type="radio" name="difficulty" value="3">難しい <br> <input type="submit" value="送信"> </form>
~phpの取得部分~
<?php require_once '\MAMP\db_config.php'; try { $dbh = new PDO('mysql:host=localhost;dbname=db1;charset=utf8', $user, $pass); $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $sql = "SELECT * FROM nostalgia"; $stmt = $dbh->query($sql); $result = $stmt->fetchAll(PDO::FETCH_ASSOC); echo "<table>\n"; echo "<tr>\n"; echo "<th>ソフトタイトル</th><th>評価点</th><th>難易度</th>\n"; echo "</tr>\n"; foreach ($result as $row) { echo "<tr>\n"; echo "<td>" . htmlspecialchars($row['soft_name'],ENT_QUOTES,'UTF-8') . "</td>\n"; echo "<td>" . htmlspecialchars($row['score'],ENT_QUOTES,'UTF-8') . "</td>\n"; echo "<td>" . htmlspecialchars($row['difficulty'],ENT_QUOTES,'UTF-8') . "</td>\n"; echo "<td>\n"; echo "<a href=detail.php?id=" . htmlspecialchars($row['id'], ENT_QUOTES, 'UTF-8') . ">詳細</a>\n"; echo "|<a href=edit.php?id=" . htmlspecialchars($row['id'], ENT_QUOTES, 'UTF-8') . ">変更</a>\n"; echo "|<a href=delete.php?id=" . htmlspecialchars($row['id'], ENT_QUOTES, 'UTF-8') . ">削除</a>\n"; echo "</td>\n"; echo "</tr>\n"; } echo "</table>\n"; $dbh = null; } catch (Exception $e) { echo "エラー発生: " . htmlspecialchars($e->getMessage(), ENT_QUOTES, 'UTF-8') . "<br>"; die(); } ?>
require_once '\MAMP\db_config.php'; $soft_name = $_POST['soft_name']; $impressions = $_POST['impressions']; $category = (int) $_POST['category']; $difficulty = (int) $_POST['difficulty']; $score = (int) $_POST['score']; try { include_once '\MAMP\error_check.php'; $dbh = new PDO('mysql:host=localhost;dbname=db1;charset=utf8', $user, $pass); $dbh->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $sql = "INSERT INTO nostalgia (soft_name, category, difficulty, score, impressions) VALUES (?, ?, ?, ?, ?)"; $stmt = $dbh->prepare($sql); $stmt->bindValue(1, $soft_name, PDO::PARAM_STR); $stmt->bindValue(2, $category, PDO::PARAM_INT); $stmt->bindValue(3, $difficulty, PDO::PARAM_INT); $stmt->bindValue(4, $score, PDO::PARAM_INT); $stmt->bindValue(5, $impressions, PDO::PARAM_STR); $stmt->execute(); $dbh = null; echo "感想の登録が完了しました。<br>"; echo "<a href='index.php'>トップページへ戻る</a>"; } catch (Exception $e) { echo "エラー発生: " . htmlspecialchars($e->getMessage(), ENT_QUOTES, 'UTF-8') . "<br>"; die(); }