codeigniter 使用JQUERY、 AJAX 和PHP填充选择框

lztngnrs  于 12个月前  发布在  jQuery
关注(0)|答案(1)|浏览(86)

我之前发布了一个问题,没有太多的运气,我希望清除第二个下拉列表的内容,并重新填充下拉列表,这取决于第一个下拉列表中的值。
我有以下选择框,如下所示:

<select name = "car" id="Cars" onchange="myFunction(this)">
            <option value="0">Toyota</option>
            <option value="1">Audi</option>
            <option value="2">Suzuki</option>
   </select>

在这个下拉列表下面,我还有另一个模型下拉列表:

<select id="emptyDropdown">
            <option value="0">R8</option>
            <option value="1">Quattro</option>
            <option value="2">A6 hatchback</option>
    </select>

onchange我想清除第二个下拉列表,并填充与汽车品牌相关的模型。例如。

Audi - A8, A6, A4 etc.
Suzuki - Swift, Panda etc.

<script>
  function myFunction(obj)
  {
    $('#emptyDropdown').empty()
    var dropDown = document.getElementById("carId");
    var carId = dropDown.options[dropDown.selectedIndex].value;
    $.ajax({
            type: "POST",
            url: "/project/main/getcars",
            data: { 'carId': carId  },
            success: function(msg){
                ?????????
            }
        });
  }
</script>

然后,我有以下PHP函数,如下所示(我使用codeigniter)-此函数使用Car ID并返回所有型号的列表,如下所示:

public function getCars(){
        $this->load->model('car_model');

        $this->form_validation->set_rules('carId', 'carId', 'trim|xss_clean');

        if($this->form_validation->run()){
            $carId = $this->input->post('carId');
            $carModels = $this->user_management_model->getCarModels($carId);
        } else {
            echo "error";
        }   
}

然后我不知道如何返回PHP生成的数组中的每个元素,以重新填充ID =“emptyDropdown”的下拉列表。PHP生成的数组具有以下结构:

Array ( [0] => Array ( [ModelName] => R8 V6 Twin Turbo [ModelID] => 19 ) [1] => Array ( [ModelName] => A6 Hatchback  [ModelID] => 107 ) )

为了澄清这个问题-我如何把数组中的每个元素,并把它作为一个新的选项在下拉列表?有没有一种方法可以将数组返回给javscript,然后在 AJAX 调用的success方法中重新填充?
任何帮助将不胜感激,非常感谢提前

ccrfmcuu

ccrfmcuu1#

此答案提供了对代码的必要修改。

**免责声明:**在没有看到确切安装的情况下,请注意可能有各种因素导致安装中无法“按原样”工作。我不知道你的路由是如何设置的,或者你是否使用Firebug或其他控制台来监视 AJAX 调用,但这应该给予你一些构建块:

首先,将你的php修改为output数组作为json编码的字符串:

public function getCars(){
        $this->load->model('car_model');

        $this->form_validation->set_rules('carId', 'carId', 'trim|xss_clean');

        if($this->form_validation->run()){
            $carId = $this->input->post('carId');
            $carModels = $this->user_management_model->getCarModels($carId);
            // Add below to output the json for your javascript to pick up.
            echo json_encode($carModels);
            // a die here helps ensure a clean ajax call
            die();
        } else {
            echo "error";
        }   
}

然后,修改你的脚本 AJAX 调用,让它有一个成功的回调函数来获取数据并将其添加到你的下拉列表中:

function myFunction(obj)
  {
    $('#emptyDropdown').empty()
    var dropDown = document.getElementById("carId");
    var carId = dropDown.options[dropDown.selectedIndex].value;
    $.ajax({
            type: "POST",
            url: "/project/main/getcars",
            data: { 'carId': carId  },
            success: function(data){
                // Parse the returned json data
                var opts = $.parseJSON(data);
                // Use jQuery's each to iterate over the opts value
                $.each(opts, function(i, d) {
                    // You will need to alter the below to get the right values from your json object.  Guessing that d.id / d.modelName are columns in your carModels data
                    $('#emptyDropdown').append('<option value="' + d.ModelID + '">' + d.ModelName + '</option>');
                });
            }
        });
  }

再一次-这些是积木。使用您的浏览器控制台或Firebug等工具来监视 AJAX 请求和返回的数据,以便您可以进行适当的修改。祝你好运!

相关问题