2012-08-12 110 views
0

我有一系列相互依存的选择列表,它们可以在CI之外正常工作。当我试图在Codeigniter中实现它时,由于没有填充第一个选择列表,所以我没有出现,或者回显代码不正确,或者我不知道是什么。这里的问题将引用第一个选择列表,也就是说,你不会看到任何jquery,因为第一个直接从数据库填充而没有任何“功能改变”。Codeigniter:相互依赖的下拉列表。完成代码

所以这里的模块:

VIEW

<?php echo form_open('control_form/add_all'); ?> 
     <label for="f_state">State<span class="red">*</span></label> 
     <select id="f_state" name="f_state"> 
      <option value=""></option> 
      <?php 

       foreach($result as $row) 
       { 
       echo '<option value="' . $row->pais_id . '">' . $row->pais_name . '</option>'; 
       } 

      ?> 
     </select> 

     <label for="f_city">City<span class="red">*</span></label> 
     <!--this will be filled based on the tree selection above--> 
     <select id="f_city" name="f_city" id="f_city_label"> 
      <option value=""></option> 
     </select> 

     <label for="f_membername">Member Name<span class="red">*</span></label> 
     <input type="text" name="f_membername"/> 
<?php echo form_close(); ?> 

控制

public function add_all() 
    { 

     #Validate entry form information 
     $this->load->model('model_form','', TRUE);   
     $this->form_validation->set_rules('f_state', 'State', 'required'); 
     $this->form_validation->set_rules('f_city', 'City', 'required'); 
     $this->form_validation->set_rules('f_membername', 'Member Name', 'required'); 

     $data['city'] = $this->model_form->get_state(); //gets the available groups for the dropdown 


     if ($this->form_validation->run() == FALSE) 
     { 
       $this->load->view('view_form_all', $data); # parece ser que vuelve a meter los mismos datos que tenia la Form 
     } 
     else 
     { 
      #Add Member to Database 
      $this->model_form->add_all(); 
      $this->load->view('view_form_success'); 
     } 


    } 

模型

<?php 
class Model_form extends CI_Model 
{ 
     function __construct() 
    { 
      // Call the Model constructor 
      parent::__construct(); 
    } 

    function get_state() 
    { 
     $query = $this->db->query('SELECT pais_id, pais_name FROM pais'); 
     return $query->result(); 
    } 


    function add_all() 
    { 
     $v_state = $this->input->post('f_state'); 
     $v_membername = $this->input->post('f_membername'); 

     $data = array(
       'pais_id' => NULL, 
       'pais_name' => $v_state 

     ); 

     $this->db->insert('members', $data); 
    } 



} 
+0

你在哪里发送'$ result'到视图? – 2012-08-12 09:11:51

+0

嗯我相信这里:$ this-> load-> view('view_form_all',$ data);即,$ data是从Model查询到数据库的数组。如果选择列表没有被触及,那么它应该与数据一起加载视图 – iaintunderstand 2012-08-12 09:15:38

+0

注意你正在发送'$ city'而不是'$ result'。没有'$ result'变量。 – 2012-08-12 09:17:01

回答

0

你是不是发送$result的视图,你需要的东西像:

$data['result'] = ...//get some data 
$this->load->view('view_form_all',$data); 

如果你想显示的列表是城市名单,那么你需要在你的看法改变:

foreach($city as $row) 
{ 
     echo '<option value="' . $row->pais_id . '">' . $row->pais_name . '</option>'; 
} 

,因为在你的控制器,你正在做的:

$data['city'] = $this->model_form->get_state(); 
+0

但是,这不是$ data ['city'] = $ this-> model_form-> get_state();其实? :(是不是一样,我有?$ this-> load-> view('view_form_all',$ data); – iaintunderstand 2012-08-12 09:18:11

+0

是的,但在你看来你调用错误的参数,你有'$ data ['city' ]',所以在视图中,变量名将是'$ city'不是'$ result' – Tomer 2012-08-12 09:19:31

+0

好吧,让我试试吧 – iaintunderstand 2012-08-12 09:20:15