前提・実現したいこと
PHP,JavaScriptで日記帳システムを作っています。
【システムの概略】
・「新規作成」ボタンを押すと一行のアコーディオンが生成される。(DBにも生成される。)
・「新規作成」されたアコーディオンはそれぞれ独立しており、「日記のタイトル」テキストボックス
をクリックしても該当の「日記の内容」しかアコーディオンが開閉されない。
・「Delete」ボタンを押すと、該当の行のアコーディオンをDBから消す。かつ画面上からも消す。
【問題点】
「新規作成」ボタンを実装中に以下の問題が発生しました。
「新規作成」を押すと変数iで新規アコーディオンが追加されます。
(※JavaScriptだと変数iが一時的にしか保持されず、ブラウザを再度立ち上げて同じことを行おうとすると、再度i = 1
からになり、うまくいきそうにありません。)
【解決に向けて考えていること】
PHPのセッション変数をi
に格納してみようとしました。
しかし、スクリプトの中身にPHPを入れると「新規作成」ボタンが動かなくなります。
コードのどこが間違っているのでしょうか?
####問題の個所を部分的に抜粋しました↓
<script> function add() { var div_element = document.createElement("div"); <?php $_SESSION['i'] = 1; ?> div_element.innerHTML = '<div id="accordion"><div class="card"><div class="card-header" id="headingOne"><h5 class="mb-0"><button class="btn btn-link" data-toggle="collapse" data-target="#collapse' + i +'" aria-expanded="true" aria-controls="collapse' + i +'"><textarea name="title" class="form-control" rows="1" maxlength="20" placeholder="日記のタイトルを入力"></textarea></button><div class="float-right"><a href="" class="btn btn-primary btn-lg active" role="button" aria-pressed="true">Delete</a></div></h5></div><div id="collapse' + i +'" class="collapse" aria-labelledby="headingOne" data-parent="#accordion"><div class="card-body"><div class="container"><form method="post">内容<textarea name="contents" class="form-control" maxlength="80" placeholder="日記の内容を入力"></textarea></form></div></div></div></div></div>'; var parent_object = document.getElementById("piyo"); parent_object.appendChild(div_element); <?php $_SESSION['i'] = $_SESSION['i'] + 1; ?> } </script>
発生している問題・エラーメッセージ
エラーメッセージはありません(Eclipseで検証済)
該当のソースコード
<!doctype html> <html lang="ja"> <head> <!-- Required meta tags --> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> <!-- Bootstrap CSS --> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous"> <title>みんなの日記帳</title> </head> <body> <h1>みんなの日記帳</h1> <!--新規作成ボタンを左上に配置 <form method="post"> <button type="submit" name = "new_column" class="btn btn-primary" value="1">新規作成</button><hr> </form>--> <!--新規作成ボタンを左絵上に配置その2--> <div> <button onclick="add();" name="new_column" class="btn btn-primary" value="1">新規作成</button> </div> <!--HTML自動生成(BootStrapで)--> <script> function add() { var div_element = document.createElement("div"); var i = 1; div_element.innerHTML = '<div id="accordion"><div class="card"><div class="card-header" id="headingOne"><h5 class="mb-0"><button class="btn btn-link" data-toggle="collapse" data-target="#collapse' + i +'" aria-expanded="true" aria-controls="collapse' + i +'"><textarea name="title" class="form-control" rows="1" maxlength="20" placeholder="日記のタイトルを入力"></textarea></button><div class="float-right"><a href="" class="btn btn-primary btn-lg active" role="button" aria-pressed="true">Delete</a></div></h5></div><div id="collapse' + i +'" class="collapse" aria-labelledby="headingOne" data-parent="#accordion"><div class="card-body"><div class="container"><form method="post">内容<textarea name="contents" class="form-control" maxlength="80" placeholder="日記の内容を入力"></textarea></form></div></div></div></div></div>'; var parent_object = document.getElementById("piyo"); parent_object.appendChild(div_element); i = i + 1; } </script> <div id="piyo"> </div> <!--アコーディオン処理--> <div id="accordion"> <div class="card"> <div class="card-header" id="headingOne"> <h5 class="mb-0"> <button class="btn btn-link" data-toggle="collapse" data-target="#collapseOne" aria-expanded="true" aria-controls="collapseOne"> <textarea name="title" class="form-control" rows="1" maxlength="20" placeholder="日記のタイトルを入力"></textarea> </button> <div class="float-right"> <a href="" class="btn btn-primary btn-lg active" role="button" aria-pressed="true">Delete</a> </div> </h5> </div> <div id="collapseOne" class="collapse" aria-labelledby="headingOne" data-parent="#accordion"> <div class="card-body"> <div class="container"> <form method="post"> 内容<textarea name="contents" class="form-control" maxlength="80" placeholder="日記の内容を入力"></textarea> </form> </div> </div> </div> </div> </div> <?php if (isset($_POST["new_column"])) { //$kbn = htmlspecialchars($_POST["new_column"], ENT_QUOTES, "UTF-8"); session_start(); $link = mysqli_connect("localhost","root","root","diary"); if(mysqli_connect_error()){ die("DBへの接続失敗!"); } } ?> <!-- Optional JavaScript --> <!-- jQuery first, then Popper.js, then Bootstrap JS --> <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script> <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js" integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy" crossorigin="anonymous"></script> </body> </html>
試したこと
PHPのセッション変数をJavaScriptのfunction add()関数の中に入れてみようとしましたが記述方法が間違っているのか、「新規作成」ボタンを押しても何も動作しなくなりました。
補足情報(FW/ツールのバージョンなど)
エディタ:Brackets & Eclipse
OS:windows10
よろしくお願いいたします。