如何将Mutiple数据传递给Codeigniter控制器

时间:2018-08-13 08:48:42

标签: php codeigniter codeigniter-3 codeigniter-query-builder

我正在处理模板,我需要将数据库结果传递到视图页面中的jquery数据表中。现在的问题是,还有一个名为application/view/admin/layout.php的模板,我们在全球范围内使用该模板,其中包括页眉,页脚,侧边栏和其他全局库。 现在的问题是我无法将此模板传递给控制器​​。

Belwo是我的控制器(application / controllers / admin / Applications.php

       <?php
    defined('BASEPATH') OR exit('No direct script access allowed');

    class Applications extends MY_Controller {
        public function __construct(){
            parent::__construct();

        }

        public function appindex(){
            $data['view'] = 'admin/dashboard/index';
            $this->load->model('admin/App_model');
            $result['data']=$this->App_model->applists();
            $this->load->view('admin/layout', $data, $result);

        }               
            }

?>  

下面是我的模型(application / models / admin / App_model.php

    <?php
if ( ! defined('BASEPATH')) exit('No direct script access allowed');

class App_model extends CI_Model{

    public function applists(){

            $query=$this->db->query("select * from tblapps");
            return $query->result();

        }       
}
?>

这是我的全局文件(layout.php)视图的代码

            <section id="container">
            <!--header start-->
            <header class="header white-bg">
                <?php include('include/navbar.php'); ?>
            </header>
            <!--header end-->
            <!--sidebar start-->
            <aside>
                <?php include('include/sidebar.php'); ?>
            </aside>
            <!--sidebar end-->
            <!--main content start-->
            <section id="main-content">
                <div class="content-wrapper" style="min-height: 394px; padding:15px;">
                    <!-- page start-->
                    <?php $this->load->view($view);?>
                    <!-- page end-->
                </div>
            </section>
            <!--main content end-->
            <!--footer start-->
            <footer class="main-footer">
                <strong>Copyright © 2018 <a href="#">Indian I Services</a></strong> All rights
                reserved.
            </footer>
            <!--footer end-->
        </section>

这是我正在传递数据库查询结果的视图页面中的index.php。

 <tbody>
            <?php
                 $i=1;              
                foreach($data as $row)
            {
               echo "<tr>";
               echo "<td>".$i."</td>";
               echo "<td>".$row->app_id."</td>";
               echo "<td>".$row->firstname."</td>";
               echo "<td>".$row->email."</td>";
                echo "<td>".$row->sdate."</td>";
               echo "</tr>";
               $i++;
             }
            ?>              
            </tbody>

它给我错误

  

遇到PHP错误       严重程度:注意       消息:未定义的变量:数据       文件名:applications / index.php       行号:42

如果我在控制器中使用此代码-它仅显示表格。但是如何包含该模板文件,使其可以显示所有页眉,页脚和菜单。

    <?php
    defined('BASEPATH') OR exit('No direct script access allowed');

    class Applications extends MY_Controller {
        public function __construct(){
            parent::__construct();

        }

        public function appindex(){
            $this->load->model('admin/App_model');
            $result['data']=$this->App_model->applists();
            $this->load->view('admin/applications/index', $result);

        }               
            }

?>

2 个答案:

答案 0 :(得分:3)

希望这对您有帮助:

同时通过viewdata结果:

public function appindex()
{
    $result['view'] = 'admin/dashboard/index';
    $this->load->model('admin/App_model');
    $result['data'] = $this->App_model->applists();
    $this->load->view('admin/layout', $result);
}

您的视图应如下所示:

<section id="main-content">
            <div class="content-wrapper" style="min-height: 394px; padding:15px;">
                <!-- page start-->
                <?php if ( !empty($view))
                {
                   $this->load->view($view);
                }?>
                <!-- page end-->
            </div>
</section>

这是您的data部分

<tbody>
  <?php
  if (! empty($data))
  {
    $i=1;              
    foreach($data as $row)
    {
      echo "<tr>";
      echo "<td>".$i."</td>";
      echo "<td>".$row->app_id."</td>";
      echo "<td>".$row->firstname."</td>";
      echo "<td>".$row->email."</td>";
      echo "<td>".$row->sdate."</td>";
      echo "</tr>";
      $i++;
    }
  }
  ?>              
</tbody>

更多信息:https://codeigniter.com/user_guide/general/views.html#adding-dynamic-data-to-the-view

答案 1 :(得分:1)

存储您的数据并在$ data ['data']和$ data ['result']中生成结果 并传递给查看 在视野中。使用$ result和$ data

获取数据