我的问题很简单,但我并不完全理解这个概念。我在数据库中有类别表,所以我想为我的类别表中的每个记录创建一个页面
我已经在视图中显示了数据库中的记录,但我不知道如何为每个记录设置href
。
我的控制器
public function index(){
$this->load->model('Model_Category');
$data['row2']= $this->Model_Category->get_category();
$this->load->view('view_page.php',$data);
}
我的视图
<div class="row mb-4">
<div class="items mr-2 ml-2">
<?php foreach ($row2->result() as $key=>$data) : ?>
<a class="text-light listcategory" href="#"><span><?=$data->name_cat?></span></a>
<?php endforeach; ?>
</div>
</div>
那么,如何为我的所有记录创建一个页面呢?
这确实是主观的,取决于您想要如何处理URI。但对于一个简单的选项,控制器看起来像这个
class Categories extends CI_Controller {
public function __construct() {
// this makes working with urls easier
$this->load->helper('url');
}
public function index() {
$this->load->model('Model_Category');
$data['row2']= $this->Model_Category->get_category();
$this->load->view('view_page.php',$data);
}
// Below, handle the logic for displaying a single category
public function details($slug) {
$this->load->model('Model_Category');
$data['row2']= $this->Model_Category->get_category_by_slug($slug);
$this->load->view('view_details_page.php', $data);
}
}
在您的视图中,定义href如下:我在这个片段中使用了一个slug,但您可以使用任何能够唯一标识数据库中类别行的内容。
<div class="row mb-4">
<div class="items mr-2 ml-2">
<?php foreach ($row2->result() as $key => $data) : ?>
<a class="text-light listcategory" href="<?= site_url('category/details/'.$data->slug) ?>">
<span><?= $data->name_cat ?></span>
</a>
<?php endforeach; ?>
/div>
</div>
最后,在您的模型中,查询单个类别行
public function get_category_by_slug($slug) {
$this->db->select('column1, column2, column3');
$this->db->from('categories_table');
$this->db->where('unique_column', $sulg);
return $this->db->get()->result();
}