【发布时间】:2014-05-24 08:07:30
【问题描述】:
我早些时候发布了一个问题,但运气不佳,我希望清除第二个下拉列表的内容并重新填充下拉列表,具体取决于第一个下拉列表中的值。
我有如下选择框:
<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) - 该函数使用汽车 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 调用的成功方法中重新填充?
任何帮助将不胜感激,在此先感谢
【问题讨论】:
-
感谢您的代码 .. 它在我的网站上运行 ....
标签: javascript php jquery ajax codeigniter