Я не могу отобразить мои данные в таблице, используя цикл for в php.
Я использую bootstrap в качестве внешнего интерфейса и php mysql в качестве внутреннего.
Я действительно пытался отобразить данные в качестве первого изображения, но я получаю результат изображения 2 снова и снова.
Даже если я попытаюсь оформить его с помощью css, столбец и строка таблицы не отображаются так, как показано на первом изображении. Вот изображение image1 image2 Этокак я хочу, чтобы таблица выглядела как
но я получаю это
ожидаемый результат должен быть это ожидаемый результат нижемой код
<!-- language: lang-html -->
<!DOCTYPE html>
<html lang="en">
<head>
<title>Bootstrap Example</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.0/css/bootstrap.min.css">
<link rel="stylesheet" href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.0/js/bootstrap.min.js"></script>
</head>
<body>
<?php
$con = mysqli_connect('localhost','root','','reservations');
$startingDay = date('Y-m-d', strtotime("first sunday of this month -6 days"));
$numberOfDays = 35;
$dates = array();
$weekCounter = 1;
$meetingRow = '';
for ($i = 0; $i <= $numberOfDays - 1; $i++) {
$date = date('m/j/Y', strtotime("$startingDay +$i days"));
$dates[] = $date;
if (date('l', strtotime($date)) == "Monday") {
$meetingRow .= '<div class="container">';
$meetingRow .= '<table class="table" border="1" cellpadding="2" cellspacing="2">';
$meetingRow .= '<tbody>';
$meetingRow .= '<tr><td colspan="8"></td></tr>';
$meetingRow .= '<tr>';
$meetingRow .= '<th>Week ' . $weekCounter++ . '</th>';
}
$meetingRow .= '<th>';
$meetingRow .= '<p>' . $date. '</p>';
$meetingRow .= '<p>' . date('l', strtotime($date)). '</p>';
$meetingRow .= '</th>';
if (date('l', strtotime($date)) == "Sunday") {
$meeting_room_sql = "
SELECT id
, meeting_room_name
FROM meeting_room
";
$meeting_room_result = mysqli_query($con, $meeting_room_sql);
// you are to use $meeting_room_result not $meeting_room_sql error occurs in fetching from meeting_room
while ($meeting_room_row = mysqli_fetch_assoc($meeting_room_result)) {
$meeting_room_id = $meeting_room_row['id'];
$meeting_room_name = $meeting_room_row['meeting_room_name'];
$meetingRow .= '<tr>';
$meetingRow .= '<td>';
$meetingRow .= '<div>' . htmlentities($meeting_room_name, ENT_QUOTES, "UTF-8") . '</div>';
$meetingRow .= '<button type="button" class="btn btn-info btn-lg" data-toggle="modal" data-target="#meetingModal">Reserve</button>';
$meetingRow .= '</td>';
$reserved_sql = "SELECT meeting_room_id, reserved_date FROM meeting";
$reserved_result = mysqli_query($con, $reserved_sql);
while ($reserved_row = mysqli_fetch_assoc($reserved_result)) {
$reserved_room_id = $reserved_row['meeting_room_id'];
$reserved_date = $reserved_row['reserved_date'];
if ($reserved_room_id == $meeting_room_id) {
$meetingRow .= '<td>' . htmlentities('Meeting Reserved ' . date('m/j/Y', strtotime($reserved_date)), ENT_QUOTES, "UTF-8"). '</td>';
} else {
$meetingRow .= '<td><br /></td>';
}
}
}
$meetingRow .= '<td><br /></td>';
$meetingRow .= '<td><br /></td>';
$meetingRow .= '<td><br /></td>';
$meetingRow .= '<td><br /></td>';
$meetingRow .= '<td><br /></td>';
$meetingRow .= '</tr>';
}
$meetingRow .= '</tbody></tr>';
$meetingRow .= '</table>';
$meetingRow .= '</div>';
}
echo $meetingRow;
?>
<script>
$(function() {
$("#meeting_date").datepicker();
});
</script>
</body>
</html>
{
"meeting_room": {
"Room 1": {
"id":1,
"meeting_room_name":"meeting room 1"
},
"Room 2": {
"id":2,
"meeting_room_name":"meeting room 2"
},
"Room 3": {
"id":3,
"meeting_room_name":"meeting room 3"
},
},
"meeting": {
"1": {
"id":1,
"meeting_room_id":"2",
"reserved_date":"02/02/2019"
},
"2": {
"id":2,
"meeting_room_id":"02/03/2019",
},
"3": {
"id":3,
"meeting_room_id":"01/31/2019",
}
}
}