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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

Q&A

解決済

1回答

806閲覧

PHPとBootStrapで日記帳を作りたい

1004

総合スコア74

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

0グッド

0クリップ

投稿2018/10/01 08:05

前提・実現したいこと

ここに質問の内容を詳しく書いてください。
PHP(BootStrap)で日記帳システムを作っています。
(※新たに日記を書きたいときは「新規作成」ボタンを押して作ります。並び順は新しい日記が上にく来るようにします。)

#####「新規作成」機能を実装中に次の問題が発生しました。
Boootstrapでアコーディオンを使うとき
67行目:「data-target="#collapseTwo"」、「aria-controls="collapseTwo"」
75行目:「div id="collapseTwo"」
のように、1,2、のように数値指定ではなく、One,Twoのように、アルファベットで指定されているため、変数で動的に書き換えができません。数値であれば、変数として扱えるため、複数回「新規作成」ボタンを押してもインクリメントで新たに日記が追加されるようになるため、実装が可能そうです。
現状、「新規作成」ボタンが1回までなら新しい日記が一つ追加されるだけの造りになっています。
これを「新規作成」ボタンが複数回押されたら、その数分だけ日記が追加されるようにしたいのですが、良い案が浮かびません。

※最終的にはこれらの日記をデータベースに保存してアプリログイン時にユーザーが自分の日記を見れるようにしたいです。

発生している問題・エラーメッセージ

※現在、特にエラーメッセージは出ておりません。

該当のソースコード

<!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> <!--アコーディオン処理--> <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への接続失敗!"); } if($_POST['new_column']){ echo "新規作成ボタンが押されました!"; //ここにアコーディオン追加処理を記述 print<<<eof <div class="card"> <div class="card-header" id="headingOne"> <h5 class="mb-0"> <button class="btn btn-link" data-toggle="collapse" data-target="#collapseTwo" aria-expanded="true" aria-controls="collapseTwo"> <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="collapseTwo" 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> eof; } } ?> <!-- 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>

試したこと

HTMLを生成できるようにprint<<<eof(62行目) と eof;(86行目)でコードを囲いました。 

補足情報(FW/ツールのバージョンなど)

OS:windows10
エディタ:Eclipse

良い案が浮かびません、分かる方、ご教示お願いいたします。

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

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

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

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

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

m.ts10806

2018/10/01 08:46

毎度ですがタイトルと内容が遠いです。タイトルは内容の要件によった内容にしてください。タイトルだけ並べて見たときにほぼ同じで何が問題なのか分かりません。
m.ts10806

2018/10/01 08:55

JavaScriptは頑なに使おうとしないのはどのような理由があるのでしょうか。htmlだけでは表現に限界があります。
1004

2018/10/01 09:27

JavaScriptを使ってやりたいことが実現できるなら、挑戦したいです。今まで、phpとHTMLだけで日記帳を完成させようとしていましたが、JavaScriptも改めて勉強してみたいと思います。
m.ts10806

2018/10/01 10:38

ご存知かとは思いますが質問は編集できるので適宜ご対応ください。またWebやりたいのであれば何かない限りJavaScriptは必須技術です。
1004

2018/10/02 07:04

ネット上に自分がやりたいようなことが載っているサンプルがjavascriptにありました。まずはサンプルを研究していこうと思います。
guest

回答1

0

ベストアンサー

1,2、のように数値指定ではなく、One,Twoのように、アルファベットで指定されているため、変数で動的に書き換えができません。数値であれば、変数として扱えるため、複数回「新規作成」ボタンを押してもインクリメントで新たに日記が追加されるようになるため、実装が可能そうです。

同じ構造が複数回現れるようなHTMLでは id ではなく、class で表現します。
id をつけていないからといって、不都合なことは生じません。

※最終的にはこれらの日記をデータベースに保存してアプリログイン時にユーザーが自分の日記を見れるようにしたいです。

アプローチが逆だと思います。

世の中の開発者のほとんどは、DBに登録されたレコードを起源として、アコーディオンを生成するでしょう。
新規登録の際も、DBにレコードを登録し、成功したら、またそのレコードセットをアコーディオンで表現するという実装をします。

投稿2018/10/01 08:52

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

1004

2018/10/01 09:31

ありがとうございます。 まずは、HTMLの見直しとDBを作るところから始めようと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問