2013-03-16 122 views
1

我收集了一個國家和州的代碼,其中我從選擇標籤中選擇一個國家/地區名稱,然後在下一個選擇框中選擇國家/地區下的所有狀態顯示。所有數據來自MySQL,並由jQuery,ajax處理。

我無法從控制器獲得價值。爲什麼?

$data=$this->input->post('state',true) 

我的代碼如下:CI模型

<?php 
/* File : ajax.php 
* Author : Manish Kumar Jangir 
*/ 
class AJAX { 

    private $database = NULL; 
    private $_query = NULL; 
    private $_fields = array(); 
    public $_index = NULL; 
    const DB_HOST = "localhost"; 
    const DB_USER = "root"; 
    const DB_PASSWORD = ""; 
    const DB_NAME = "csc"; 


    public function __construct(){ 
     $this->db_connect();     // Initiate Database connection 
     $this->process_data(); 
    } 

    /* 
    * Connect to database 
    */ 
    private function db_connect(){ 
     $this->database = mysql_connect(self::DB_HOST,self::DB_USER,self::DB_PASSWORD); 
     if($this->database){ 
      $db = mysql_select_db(self::DB_NAME,$this->database); 
     } else { 
      echo mysql_error();die; 
     } 
    } 

    private function process_data(){ 
     $this->_index = ($_REQUEST['index'])?$_REQUEST['index']:NULL; 
     $id = ($_REQUEST['id'])?$_REQUEST['id']:NULL; 
     switch($this->_index){ 
      case 'country': 
       $this->_query = "SELECT * FROM countries"; 
       $this->_fields = array('id','country_name'); 
       break; 
      case 'state': 
       $this->_query = "SELECT * FROM states WHERE country_id=$id"; 
       $this->_fields = array('id','state_name'); 
       break; 
      case 'city': 
       $this->_query = "SELECT * FROM cities WHERE state_id=$id"; 
       $this->_fields = array('id','city_name'); 
       break; 
      default: 
       break; 
     } 
     $this->show_result(); 
    } 

    public function show_result(){ 
     echo '<option value="">Select '.$this->_index.'</option>'; 
     $query = mysql_query($this->_query); 
     while($result = mysql_fetch_array($query)){ 
      $entity_id = $result[$this->_fields[0]]; 
      $enity_name = $result[$this->_fields[1]]; 
      echo "<option value='$entity_id'>$enity_name</option>"; 
     } 
    } 
} 

$obj = new AJAX; 

?> 

這是我的看法:

<html> 
<head> 
<title>Country State City Dependent Dropdown using Ajax</title> 
<script type="text/javascript" src="<?php echo base_url(); ?>js/jquery-1.5.2.min.js"></script> 
<style type="text/css"> 
body{ 
    font-family:arial; 
    color:#666; 
} 
form select{ 
    padding:5px; 
    border:1px solid #aaa; 
    border-radius:4px; 
    width:120px; 
} 

form label{ 
    font-size:12px; 
    font-weight:bold; 
} 
</style> 
<script type="text/javascript"> 
$(document).ready(function(){ 
    load_options('','country'); 
}); 

function load_options(id,index){ 
    $("#loading").show(); 
    if(index=="state"){ 
     $("#city").html('<option value="">Select city</option>'); 
    } 
    $.ajax({ 
     url: "<?php echo base_url(); ?>index.php/welcome/includ.html?index="+index+"&id="+id, 
     complete: function(){$("#loading").hide();}, 
     success: function(data) { 
      $("#"+index).html(data); 
     } 
    }) 
} 
</script> 
</head> 
<body> 
<div style="width:800px; margin:auto;padding-top:100px;"> 
<h1>Country,State,City dynamic dependent dropdown using Ajax and Jquery</h1> 
<form action="<?php echo base_url(); ?>index.php/city_ajax/show_result" method="post"> 
     <label>Select Country</label> 
     <select id="country" onchange="load_options(this.value,'state');"> 
      <option value="">Select country</option> 
     </select> 
     &nbsp;&nbsp;&nbsp; 
     <label>Select State</label> 
     <select id="state" onchange="load_options(this.value,'city');"> 
      <option value="">Select state</option> 
     </select> 
     &nbsp;&nbsp;&nbsp; 
     <label>Select city</label> 
     <select id="city"> 
      <option value="">Select City</option> 
     </select> 
     <img src="<?php echo base_url(); ?>loader.gif" id="loading" align="absmiddle" style="display:none;"/> 
</form> 
</div> 

</body> 
</html> 

回答

0

SELECT語句:

country_id=$id應該country_id='" . $id . "'

state_id=$id應該state_id='" . $id . "'

+0

它們都用雙引號,所以變量被解析。另外,將ID轉換爲整數將會是一件好事 – 2013-03-16 08:15:31

+0

是的,ajax.php是一個.php文件。你是否幫我轉換爲codeigniter模型和控制器文件。並且我正在編輯類型:「post」,但是我仍然無法獲得$ data = $ this-> input-> post('country',true)控制器中的值。 $數據= $這個 - >輸入 - >柱( '州',TRUE);我不明白我會在哪裏改變country_id ='「。$ id。」'和state_id ='「。$ id。」'請幫助我(我是程序世界的新手) – user2176340 2013-03-16 14:38:21

1

至於你說的CI模式:

CI中你必須CI_Model延伸:爲了使CI型其他明智

class Exam_model extends CI_Model {} 

它僅僅是一個.PHP文件

而且

這個

$data=$this->input->post('state',true); 

你試圖評估參數,它需要一個型阿賈克斯作爲POST

 url: "<?php echo base_url(); ?>index.php/welcome/includ.html?index="+index+"&id="+id, 
    complete: function(){$("#loading").hide();}, 
    type:"POST", // you have to mention post type here 
    success: function(data) { 
     $("#"+index).html(data); 
    } 

希望這將有助於!

+0

是的ajax.php是a。 PHP文件。你是否幫我轉換爲codeigniter模型和控制器文件。並且我正在編輯類型:「post」,但是我仍然無法獲得$ data = $ this-> input-> post('country',true)控制器中的值。 $數據= $這個 - >輸入 - >柱( '州',TRUE);請幫幫我 – user2176340 2013-03-16 14:27:52