PHP練習問題

PHP練習問題 問61


新人に向けた超簡単な初心者向け問題を作成していこうと心も新たに穴埋め問題を作成しようと思います。

配列、ループ、条件分岐などの簡単なサンプルから問題を出してきます。
簡単なので、是非挑戦してください。

PHPをWindowsで実行したいのであれば、XAMPP(ザンプ)をインストールすると、自分のPCでも簡単に動作させることが出来ます。

インストール方法は、以下のサイトから。

WINDOWS XAMPP にて LARAVEL をインストール (XAMPP V1.8.3インストール)


phpedu61.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.4.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問題61</h1>
			</div>
			<div class="jumbotron">
			<h3>
			<?php
				$a = 1 + 2;
				[  a  ] ? '正解' : '誤り';
				echo $b;
			?>
			</h3>
			</div>
		</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を利用しています。

問題:正解と表示したい場合、[ a ]に入る適切なものはどれか選択して下さい。(複数選択可)

  1. $a == 3
  2. $b = 3
  3. $a = $b == 3
  4. $b = $a == 3

正解:4.$b = $a == 3

今回は三項演算子についての問題です。
プロジェクトによっては(又は会社レベルで)三項演算子は利用不可の場合が多いかもしれません。
javascriptなどの言語では、結構な確率で三項演算子を見る確率があるので、少し慣れておいた方が良いのではないかと思います。

ここでは、三項演算子の内容を $b へ代入するという不思議なコードになっています。
ですので、 = と == があり、プログラム初心者を惑わせます。

正解に関しては、 $b = $a == 3 ? '正解' : '誤り'; のようなコードとなります。
$bの右辺が三項演算子となり、構文は以下。

条件 ? trueの場合 : falseの場合;

これの先頭に代入式が入っているだけです。
と言ってもみずらいのが分かります。
できれば可読性を上げるためにも、こういったコードは避けたほうが良いと思います。

  • このエントリーをはてなブックマークに追加

PAGE TOP