在CodeIgniter中传递视图中的数据时出错

时间:2015-01-03 15:20:40

标签: php html arrays codeigniter

我将SQL查询结果存储在$data变量中,然后从我的模型中将其传递给search_view

        $this->db->like('LOWER(title)', strtolower($query));
        $q = $this->db->get('questions');
        $data = $q->row_array();
        $this->load->view('search_view', array('data' => $data));

我正在尝试使用以下结构在我的视图中显示所有结果:

<?php if ($data['search_type'] == 'question') { 
        foreach ($data as $question) {
?>


<div class="question-result">
    <h2><?php echo $question['title']; ?></h2>
    <p>Posted by: <a href="#"><?php echo $question['username']; ?>username</a></p>
    <p>Date Posted: <?php echo $question['date']; ?></p>
</div>


<?php } } ?>

其中$ data ['search_type']是我需要检查以查看执行了什么类型的搜索的内容,此位经过测试且工作正常,无需担心,但是

我为所有变量(例如我使用的用户名,标题和日期)收到非法字符串偏移量错误。

eddit *示例转储:

array(7) { ["question_id"]=> string(1) "3" ["title"]=> string(19) "First Question Ever" ["content"]=> string(13) "Hello Content" ["date"]=> string(19) "2015-01-03 15:08:30" ["user_id"]=> string(2) "14" ["username"]=> string(4) "Ilya" ["search_type"]=> string(8) "question" } 

出于某种原因,这不会返回多个问题,尽管搜索应该有更多。

1 个答案:

答案 0 :(得分:1)

你不需要使用另一个foreach,因为它不再是另一个维度。使用->row_array()后,只返回一行。

<?php if ($data['search_type'] == 'question') { ?>

<div class="question-result">
    <h2><?php echo $data['title']; ?></h2>
    <p>Posted by: <a href="#"><?php echo $data['username']; ?>username</a></p>
    <p>Date Posted: <?php echo $data['date']; ?></p>
</div>

<?php } ?>

如果您希望获得更多结果,请改用->result_array()

$data = $q->result_array();

然后查看:

<?php foreach ($data as $question): ?>
    <?php if ($question['search_type'] == 'question') { ?>
        <div class="question-result">
            <h2><?php echo $question['title']; ?></h2>
            <p>Posted by: <a href="#"><?php echo $question['username']; ?>username</a></p>
            <p>Date Posted: <?php echo $question['date']; ?></p>
        </div>
    <?php endif; ?>
<?php endforeach; ?>

或者也可以添加$this->db->where('search_type', 'question'),这样就不必在上面的循环中将if放在foreach中。