2011-05-13 46 views
0

我正在尝试为CRUD活动编写一个简洁的更新控制器。这是基本的代码:使用CI CRUD传递数据从数据库更新表格

控制器:

function update($id) 
    {   
     $this->form_validation->set_rules('name','Name','required');    
     $this->form_validation->set_rules('age','Age','required|is_numeric');   
     $this->form_validation->set_rules('country','Country',''); 

     $this->form_validation->set_error_delimiters('<br /><span class="error">', '</span>'); 

     if ($this->form_validation->run() == FALSE) { 

      //Failed validation or first run 
      $data = $this->my_model->get_record($id); 

      $this->load->view('myform_view', $data); 

     } else { 

      //Validation success, update DB 

     } 
    } 

查看:

<?php 

$attributes = array('class' => '', 'id' => ''); 
echo form_open('my_form', $attributes); ?> 

<p> 
     <label for="name">Name</label> 
     <?php echo form_error('name'); ?> 
     <br /><input id="name" type="text" name="name" value="<?php echo set_value('name'); ?>" /> 
</p> 

<p> 
     <label for="age">Age</label> 
     <?php echo form_error('age'); ?> 
     <br /><input id="age" type="text" name="age" value="<?php echo set_value('age'); ?>" /> 
</p> 

<p> 
     <label for="country">Country</label> 
     <?php echo form_error('country'); ?> 
     <br /><input id="country" type="text" name="country" value="<?php echo set_value('country'); ?>" /> 
</p> 


<p> 
     <?php echo form_submit('submit', 'Submit'); ?> 
</p> 

<?php echo form_close(); ?> 

这是基本的结构,但是第一次的形式运行,没有经过验证的数据。因此我必须从数据库中抓取这个。什么是最好的方式将它传递给第一次运行的视图?然后一旦表单被提交,如果验证失败,我希望失败的数据显示不再从数据库重新加载。什么是最好的方法来做到这一点?

回答

1

您应该有另一种查看方面的方法。然后根据“更新”方法提交表单。在那里,你现在定义了form_validation。

我问了一个类似的问题。看到这个link

+0

世界上没有办法给它的所有压缩成一个控制器?另外我如何填充视图文件。目前我使用set_value()。 – Alex 2011-05-13 21:18:08

+1

我已经更新了我的答案。我想你在问我刚才问过的同样的事情。 – luckytaxi 2011-05-13 22:06:59

0

抢在更新控制器的数据先为编辑如

$query = $this->db->where('id',$id)->get('table_name'); 
$data['edit'] = $query->result_array(); 

,然后将其签入视图文件

value="<?php if(isset($edit[0]['age'])){echo $edit[0]['age'];}else{echo set_value('age');}?>"