新人に向けた超簡単な初心者向け問題に行ってみたいと思います。
GET、POSTなど、初心者にもわかる問題を出していきます。
簡単なので、是非挑戦してください。
PHPをWindowsで実行したいのであれば、XAMPP(ザンプ)をインストールすると、自分のPCでも簡単に動作させることが出来ます。
インストール方法は、以下のサイトから。
WINDOWS XAMPP にて LARAVEL をインストール (XAMPP V1.8.3インストール)
phpedu75.php
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>tech.pjin.jp HTML5 Template</title> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css"> <!--[if lt IE 9]> <script src="https://cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.3/html5shiv.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/respond.js/1.4.2/respond.min.js"></script> <![endif]--> </head> <body> <div class="container"> <div class="page-header"> <h1><i class="fa fa-check-square"></i> PHP問題75</h1> </div> <div class="jumbotron"> <?= htmlspecialchars(nl2br(@$_POST['message'])) ?> </div> <form action="<?= $_SERVER['PHP_SELF'] ?>" method="POST"> <div class="row"> <div class="col-sm-offset-3 col-sm-6"> <div class="form-group"> <label>好きな果物</label> <textarea name="message" class="form-control"></textarea> </div> <button type="submit" class="btn btn-primary">送信</a> </div> </div> </form> </div> <script src="https://code.jquery.com/jquery-1.11.3.min.js"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script> </body> </html>
※CSSには、Bootstrap、Font-Awesomeを利用しています。
※Javascriptには、jQuery1.11.3を利用しています。
問題:画面を表示し、みかん[改行]バナナと入力後、送信ボタンを押下しました。画面に表示される内容はどれか選択して下さい。(複数選択可)
- みかん バナナと表示される。
- みかんの後改行され、バナナと表示される。
- みかん<br/>バナナと表示される。
- 何も表示されない
- エラーとなる
正解:3.みかん<br/>バナナと表示される。
今回はtextareaの問題です。
よく、入力に改行コード(改行)が含まれている場合に、表示が改行されませんと質問を受けます。
HTMLの改行は<br>
と説明しているのですが、textareaに改行コード(\n 又は \r\n)を入力し
表示して改行されると勘違いされている方が多い(忘れているのかも知れませんが)気がします。
ここで、改行コード(\n 又は \r\n)を<br>
に変換する関数nl2br
が出てくるわけですが、
今回の問題では、htmlspecialchars
の中で呼んでいます。
そもそも、htmlspecialcharsはHTMLタグをエスケープします。
ですので、<
と >
がエスケープされ、選択肢3のように表示されてしまいます。
正しく改行したい場合は、nl2br(htmlspecialchars(@$_POST['message']))
と書くと改行されて表示されます。
コードを書いて正しいはずと思っても、以外と落とし穴があり、うまくいかない場合が多いです。
プログラムを作成したら必ずテストするように心がけましょう!