Пропустить шаг, если значение не совпадает в цикле foreach + php - PullRequest
0 голосов
/ 23 февраля 2019

Я должен отобразить значение td в соответствии с соответствием th-го значения.Здесь в таблице ниже есть th, который имеет даты месяца.В $monthdays я получаю подсчет дней месяца, а в $listmonthdisplay я получаю все даты месяцев.
В массиве $employeeDetail я получаю даты месяца.В таблице я делаю foreach, чтобы отобразить Внимание / Дата , если Дата_Патчины равно $listmonthdisplay, но если в массиве $employeeDetail отсутствуют какие-либо даты, цикл завершается сбоем или не выполняетсявперед.Здесь Как я могу правильно отобразить значение ТБ?

$monthdays=28;
$listmonthdisplay=[
  "0"=>"01-02-2019",
  "1"=>"02-02-2019",
  "2"=>"03-02-2019",
  "3"=>"04-02-2019",
  "4"=>"05-02-2019", ............"28"=>"05-02-2019"
]

$employeeDetail=[
     "0"=>["attendence_date"=>"01-02-2019"],
     "1"=>["attendence_date"=>"02-02-2019"],
     "2"=>["attendence_date"=>"05-02-2019"],
     "3"=>["attendence_date"=>"08-02-2019"],
     "5"=>["attendence_date"=>"09-02-2019"]
  ]   
 <table>
  <tr>
    <?php for($i=0;$i<$monthdays;$i++){ ?>
    <th><?php echo $listmonthdisplay[$i]?></th>
    <?php }?>
 </tr>
<tr>
  <?php for($i=0;$i<$monthdays;$i++){ ?>
  <td>
 <?php
   if((isset($employeeDetail[$i]) && $listmonthdisplay[$i]==$employeeDetail[$i]['attendence_date']){
     echo $employeeDetail[$i]['attendence_date'];
   }?>
 </td>
  <?php }?>
 </tr>

 </table>


Current output:

 <table>
  <tr>
    <th>01-02-2019</th>
    <th>02-02-2019</th>
    <th>03-02-2019</th>
    <th>04-02-2019</th>
    <th>05-02-2019</th>
    <th>06-02-2019</th>
    <th>07-02-2019</th>
    <th>08-02-2019</th>
    <th>09-02-2019</th>........<th>28-02-2019</th>
 </tr>
<tr>
    <td>01-02-2019</td>
    <td>02-02-2019</td>
    <td></td>
    <td></td>
    <td></td>
    <td></td>
    <td></td>
    <td></td>
    <td></td>.......<td></td>
 </tr>

 </table>


Expected output:

 <table>
  <tr>
    <th>01-02-2019</th>
    <th>02-02-2019</th>
    <th>03-02-2019</th>
    <th>04-02-2019</th>
    <th>05-02-2019</th>
    <th>06-02-2019</th>
    <th>07-02-2019</th>
    <th>08-02-2019</th>
    <th>09-02-2019</th>
 </tr>
<tr>
    <td>01-02-2019</td>
    <td>02-02-2019</td>
    <td></td>
    <td></td>
    <td>05-02-2019</td>
    <td></td>
    <td></td>
    <td>08-02-2019</td>
    <td>09-02-2019</td>.......<td></td>
 </tr>

 </table>

1 Ответ

0 голосов
/ 23 февраля 2019

Я отредактировал его, и он работает прямо сейчас.

<?php
$monthdays=28;
$listmonthdisplay=[
    "0"=>"01-02-2019",
    "1"=>"02-02-2019",
    "2"=>"03-02-2019",
    "3"=>"04-02-2019",
    "4"=>"05-02-2019",
    "5"=>"06-02-2019",
    "6"=>"07-02-2019",
    "7"=>"08-02-2019",
    "8"=>"09-02-2019",
    "9"=>"10-02-2019",
    "10"=>"11-02-2019",
    "11"=>"12-02-2019"
    ...
];
$employeeDetail=[
    "0"=>["attendence_date"=>"01-02-2019"],
    "1"=>["attendence_date"=>"02-02-2019"],
    "2"=>["attendence_date"=>"05-02-2019"],
    "3"=>["attendence_date"=>"08-02-2019"],
    "5"=>["attendence_date"=>"09-02-2019"]
];
$tmpArray = array_column($employeeDetail, 'attendence_date');
?>
<table>
    <tr>
        <?php 
        for($i=0;$i<$monthdays;$i++){ 
            echo "<th>".$listmonthdisplay[$i]."</th>";
        }
        ?>
    </tr>
    <tr>
        <?php 
        for($i=0;$i<$monthdays;$i++){
            echo "<td>";
            if(in_array($listmonthdisplay[$i], $tmpArray)){
                echo $listmonthdisplay[$i];
            }
            echo "</td>";
        }
        ?>
        </tr>
</table>

Я изменил две вещи, и он работает прямо сейчас
Сначала добавьте этот код:

$tmpArray = array_column($employeeDetail, 'attendence_date');

для получения одномерного массива дат для печати
Второе - изменить условие на дату поиска в $ tmpArray

...