簡體   English   中英

CodeIgniter:嘗試根據第一個選擇選項的選擇從數據庫表中加載選項值

[英]CodeIgniter: Trying to load the option values from database table based on the selection of first select option

我正在使用CodeIgniter,並且有一個帶有2個選擇選項的表單。 第一個選擇選項是“汽車制造”,第二個選擇選項是“制造”。 如果從“ BMW”中選擇“汽車制造商”,則第二個選擇選項中的值將更改並顯示所有BMW制造的模型。

**WelcometoDemoCar.php (View)**

*//to get the Car Make List Box*

<input type = "text" name = "car_list" list="car_dalalist" id = "car_list" class = "inktext inklarge" placeholder = "Type of Car" required = "" autocomplete="off" />
<datalist id="car_dalalist">
 <?php foreach($carlist as $row_carlist){?>
<?php //echo $row_carlist->Make . " " .$row_carlist->Model ." " .$row_carlist->Year ;?>
<option value="<?php echo $row_carlist->Make;?>"> <?php echo $row_carlist->Make;?></option>
<?php }?> 
</datalist>


*//to get the value in the Make Select List Box*


<input type = "text" name = "car_model" list="car_model_dalalist" id = "car_model" class = "inktext inklarge" placeholder = "Car Model" required = <datalist id="car_model_dalalist">
<?php foreach($carModel as $row_carModel){?>
<?php //echo $row_carlist->Make . " " .$row_carlist->Model ." " .$row_carlist->Year ;?>
<option value="<?php echo $row_carModel->Model;?>"><?php echo $row_carModel->Model;?> </option>
<?php }?> 
</datalist> 


**Welcome.php (Controller)**

$this->data['carlist'] = $this->PostModel->getCarDetails(); 
$this->data['carModel'] = $this->PostModel->getCarModel();

**PostModel.php (Model)**



*//to get car make*

 function getCarDetails(){
  $this->db->Distinct();
  $this->db->select("Make"); 
  $this->db->from('carlist');
  $carListquery = $this->db->get();
  return $carListquery->result();
 }


 *// to get car model*


 function getCarModel(){
  $make = $this->input->post('car_list');   

  $this->db->Distinct();
  $this->db->select("Model"); 
  $this->db->from('carlist');
  $this->db->where('Make' . $make);
  $carmodelquery = $this->db->get();
  return $carmodelquery->result();
 }


public function get_data()
 {
      $value = $this->input->post("value");
      $data = $this->PostModel->get_data($value);
      $option ="";
      foreach($data as $d)
      {
         $option .= "<option value='".$d->id."' >".$d->Model."</option>";
      }
       echo $option;
 }

我嘗試過使用ajax在各種站點上發布的解決方案,但是我認為我的值沒有發布到控制器上。

阿賈克斯代碼

    $("#car_list").on("change",function(){ 
    var value = $(this).val(); 
    $.ajax({ url : "welcome/get_data", 
    type: "post", 
    data: {"value":'value'}, 

    success : function(data){ 
    $("#car_model").html(data); 
    }, 
   });
  });

非常感謝您的時間和幫助。

預先感謝。

關於代碼有幾個問題。
供將來參考:請參閱OP上的評論

主要問題是點擊處理程序:

    $("#car_list").on("change",function(){ 
     var value = $(this).val(); 
     $.ajax({ url : "welcome/get_data", 
     type: "post", 
     data: {"value":value}, //OP originally used single quotes on the value therefore passing a string instead of the actualy variable

     success : function(data){ 
     $("#car_model").html(data); 
     }, 
     });
     });

控制器和模型問題

 public function get_data()
 {
      $data = $this->PostModel->get_data(); //OP originally passed $value to the model but $value does not exist
      $option ="";

      if(count($data) > 0){
          foreach($data as $d)
          {
             $option .= "<option value='".$d->Model."' >".$d->Model."</option>";
          }
          echo $option;
      }

 }

請更新data: {"value":'value'},並更新data: {"value":value} (從value中刪除單引號)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM