Codeigniter using foreach in view

26,819

Solution 1

you just have issue in your model function foreach loop just replace that with:

$query = $this->db->query('SELECT id, date, text FROM news');
$result = $query->result_array();
return $result;

Solution 2

In your controller you're correctly assigning the result of the model to a variable:

$data['news'] = $this->testm->get_news();

but in your model you're ECHOING the result, not RETURNING them. SO $data['news'] is null (since the model's method doesn't return anything), and you can't iterate over null of course -> and that's the error in your view. Change your model to return an array, for example:

Public function get_news()
{
    $query = $this->db->query('SELECT id, date, text FROM news');
    return $query->result_array();
}

the text from my database does appear at the top of the page

because, indeed, you're echoing it (as pointed out above) before the views are outputted, that's why you see them before the rendered html

Solution 3

Try this for your answer:

your controller:

public function index($page = 'testv')
{
        if ( ! file_exists(APPPATH.'/views/'.$page.'.php'))
        {
            show_404();
        }
            $this->load->model('testm');
            $data['news'] = $this->testm->get_news();

            $this->load->view('headder');
            $this->load->view($page, $data);
            $this->load->view('footer');
}

model function :

Public function get_news()
{
    $query = $this->db->query('SELECT id, date, text FROM news');
    return $query;
}

in view file :

<?php foreach($news->result() as $new) { ?>
    <article class="article_text">
        <p class="segment_headding"><?php echo $new->date; ?></p>
            <?php echo $new->text; ?>
    </article>
<?php } ?>

Solution 4

use

foreach($thing as $something): //it is important if not compulsory to use a different name for variables!!
some HTML
endforeach;

instead

Solution 5

        <?php foreach($news as $new) { ?>
            <article class="article_text">
                <p class="segment_headding"><?php echo $new->date; ?></p>
                    <?php echo $new->text; ?>
            </article>
        <?php } ?>

Try foreach($news as $new) instead of foreach($news as $news).

Share:
26,819
Tessa
Author by

Tessa

Updated on March 19, 2020

Comments

  • Tessa
    Tessa about 4 years

    I'm using Codeigniter on an Apache xampp set up and attempting to use foreach in a view for the first time and I just can't get it to work.

    My Controller code:

    class Test extends CI_Controller {
    
            public function index($page = 'testv')
        {
                if ( ! file_exists(APPPATH.'/views/'.$page.'.php'))
                {
                    show_404();
                }
                    $this->load->model('testm');
                    $data['news'] = $this->testm->get_news();
    
                    $this->load->view('headder');
                    $this->load->view($page, $data);
                    $this->load->view('footer');
        }
    }
    

    My Model:

    class Testm extends CI_Model {
    
        public function __construct()
        {
            parent::__construct();
        }
    
        Public function get_news()
        {
            $query = $this->db->query('SELECT id, date, text FROM news');
    
            foreach ($query->result_array() as $row)
            {
                echo $row['id'];
                echo $row['date'];
                echo $row['text'];
            }
        }
    }
    

    My View:

    <main id='central_section'>
        <section id='logo_section'>
        <img src='<?php echo base_url(); ?>img/logo.png' id='small_logo' alt="Logo">
        </section>
        <section id='content'>
            <p class="large_headding">News</p>
    
                <?php foreach($news as $news) { ?>
                    <article class="article_text">
                        <p class="segment_headding"><?php echo $news->date; ?></p>
                            <?php echo $news->text; ?>
                    </article>
                <?php } ?>
            <div id="spacer"></div>
        </section>
    </main>
    

    At present I get the following warning message:

    A PHP Error was encountered
    
    Severity: Warning
    
    Message: Invalid argument supplied for foreach()
    
    Filename: views/testv.php
    
    Line Number: 18
    
    Backtrace:
    
    File: C:\xampp\htdocs\tsh\CI\application\views\testv.php
    Line: 18
    Function: _error_handler
    
    File: C:\xampp\htdocs\tsh\CI\application\controllers\test.php
    Line: 16
    Function: view
    
    File: C:\xampp\htdocs\tsh\public_html\index.php
    Line: 292
    Function: require_once
    

    But the text from my database does appear at the top of the page outside of the headder so I know the database is connecting and the data from it is being collected. Can anyone tell me where I'm going wrong?

  • Tessa
    Tessa about 9 years
    Thank you, with a little tweak to the view file to change the call from <?php echo $news->date; ?> to <?php echo $news['date']; ?> this worked perfectly!
  • Tessa
    Tessa about 9 years
    Not me, I up voted you as I found you explanation very useful. The only reason I didn't mark yours as the correct answer is that Imran answered first and his answer while not including as much detail, did answer my question. No offense meant.