Почему всегда указан неверный аргумент для foreach

Я хочу сделать диаграмму на codeigniter, но всегда терплю неудачу. пожалуйста, помогите мне неправильный текст: обнаружена ошибка PHP

Уровень серьезности: предупреждающее сообщение: для foreach () указан недопустимый аргумент. Имя файла: chart / index.php Номер строки цитаты: 16

МОЙ ВЗГЛЯД :

      <!-- **********************************************************************************************************************************************************
      MAIN CONTENT
      *********************************************************************************************************************************************************** -->
      <!--main content start-->
      <section id="main-content">
          <section class="wrapper">
            <!-- BASIC FORM ELELEMNTS -->
            <div class="row mt">

                <div class="col-lg-12">

   <?php
   #periksa array
        foreach($data as $data){
            $id_reservasi[] = $data->id_reservasi;
            $stok[] = (float) $data->stok;
        }
    ?>
</head>
<body>

    <canvas id="canvas" width="1000" height="280"></canvas>

    <!--Load chart js-->
    <script type="text/javascript" src="<?php echo base_url().'assets/chartjs/chart.min.js'?>"></script>
    <script>

            var lineChartData = {
                labels : <?php echo json_encode($id_reservasi);?>,
                datasets : [

                    {
                        fillColor: "rgba(60,141,188,0.9)",
                        strokeColor: "rgba(60,141,188,0.8)",
                        pointColor: "#3b8bba",
                        pointStrokeColor: "#fff",
                        pointHighlightFill: "#fff",
                        pointHighlightStroke: "rgba(152,235,239,1)",
                        data : <?php echo json_encode($stok);?>
                    }

                ]

            }

        var myLine = new Chart(document.getElementById("canvas").getContext("2d")).Line(lineChartData);

    </script>
      </div><!-- /col-lg-4 -->  
            </div><!-- /row -->

        </section>
      </section><!-- /MAIN CONTENT -->

МОЯ МОДЕЛЬ:

function get_chart(){
    $query = $this->db->query("SELECT id_reservasi,SUM(status_reservasi) AS stok FROM tbl_reservasi GROUP BY id_reservasi");          
        if($query->num_rows() > 0){
            foreach($query->result() as $data){
                $hasil[] = $data;
            }
            return $hasil;
        }
    }

МОЙ КОНТРОЛЛЕР:

public function chart() {
        $x['data']=$this->sistem_model->get_chart();
        $this->template_system->load('template_system','sistem/data/chart/index',$x);

    }

пожалуйста, дайте мне решение ...


person Reza Alvaero    schedule 30.07.2018    source источник
comment
Вы не можете использовать одну и ту же переменную в обоих местах foreach()   -  person Geshode    schedule 30.07.2018
comment
можешь привести мне пример?   -  person Reza Alvaero    schedule 30.07.2018
comment
все еще не решил @MagnusEriksson   -  person Reza Alvaero    schedule 30.07.2018
comment
@pradeep Я использую ссылку, как у, но получаю пустой элемент. ‹P› Сообщение: Неопределенная переменная: stok ‹/p›   -  person Reza Alvaero    schedule 30.07.2018
comment
Сделайте var_dump($data) и проверьте, что он на самом деле содержит. $data должен быть массивом или объектом, имеющим общедоступные значения или реализующим Iterator-интерфейс.   -  person Magnus Eriksson    schedule 30.07.2018


Ответы (2)


Измените foreach($data as $data){ ....} на

if ( is_array($data) ) {
   foreach($data as $item){
      $id_reservasi[] = $item->id_reservasi;
      $stok[] = (float) $item->stok;
   }
}

или измените свою функцию get_chart, чтобы всегда возвращать массив:

function get_chart(){
    $hasil = [];
    $query = $this->db->query("SELECT id_reservasi,SUM(status_reservasi) AS stok FROM tbl_reservasi GROUP BY id_reservasi");          
    if($query->num_rows() > 0){
        foreach($query->result() as $data){
             $hasil[] = $data;
        }
    }
    return $hasil;
}

справка по foreach

person nmr    schedule 30.07.2018
comment
У меня есть отредактированный пример, но я все еще не решаю - person Reza Alvaero; 30.07.2018
comment
Перед foreach проверьте, является ли переменная $data массивом: if ( is_array($data) ) { foreach ... } - person nmr; 30.07.2018
comment
спасибо тебе, хозяин - person Reza Alvaero; 30.07.2018

ПОСМОТРЕТЬ:

Примечание: as $row

if ($data) {
    foreach ($data as $row) {
        $id_reservasi[] = $row->id_reservasi;
        $stok[] = (float) $row->stok;
    }
} else {
    echo 'no data';
}

МОДЕЛЬ:

Примечание: мы можем просто вернуть result(), поскольку foreach в вашем примере не нужен / избыточен. Важно то, что мы также возвращаем false.

function get_chart() {
    $query = $this->db->query("SELECT id_reservasi,SUM(status_reservasi) AS stok FROM tbl_reservasi GROUP BY id_reservasi");
    if ($query->num_rows() > 0) {
        return $query->result();
    }
    return false;
}

Вы также можете сделать (немного чище):

ПОСМОТРЕТЬ:

Уведомление if и endif

<div class="col-lg-12">

   <?php
   /*
   #periksa array
        foreach($data as $data){
            $id_reservasi[] = $data->id_reservasi;
            $stok[] = (float) $data->stok;
        }
    */
    ?>
</head>
<body>
<?php if ($data): ?>
    <canvas id="canvas" width="1000" height="280"></canvas>

    <!--Load chart js-->
    <script type="text/javascript" src="<?php echo base_url().'assets/chartjs/chart.min.js'?>"></script>
    <script>

            var lineChartData = {
                labels : <?php echo json_encode($data['id_reservasi']);?>,
                datasets : [

                    {
                        fillColor: "rgba(60,141,188,0.9)",
                        strokeColor: "rgba(60,141,188,0.8)",
                        pointColor: "#3b8bba",
                        pointStrokeColor: "#fff",
                        pointHighlightFill: "#fff",
                        pointHighlightStroke: "rgba(152,235,239,1)",
                        data : <?php echo json_encode($data['stok']);?>
                    }

                ]

            }

        var myLine = new Chart(document.getElementById("canvas").getContext("2d")).Line(lineChartData);

    </script>
   <?php endif; ?>
      </div><!-- /col-lg-4 -->  
            </div><!-- /row -->

        </section>
      </section><!-- /MAIN CONTENT -->

МОДЕЛЬ:

function get_chart() {
    $query = $this->db->query("SELECT id_reservasi,SUM(status_reservasi) AS stok FROM tbl_reservasi GROUP BY id_reservasi");
    if ($query->num_rows() > 0) {
        $data = array();
        foreach ($query->result() as $row) {
            $data['id_reservasi'][] = $row->id_reservasi;
            $data['stok'][] = $row->stok;
        }
        return $data;
    }
    return false;
}
person Alex    schedule 30.07.2018