Codeigniter using foreach in view
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)
.
Tessa
Updated on March 19, 2020Comments
-
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 about 9 yearsThank 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 about 9 yearsNot 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.