javascript – 使用JQUERY,AJAX和PHP填充选择框
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 使用JQUERY,AJAX和PHP填充选择框,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3267字,纯文字阅读大概需要5分钟。
内容图文
![javascript – 使用JQUERY,AJAX和PHP填充选择框](/upload/InfoBanner/zyjiaocheng/712/b17948b0583048dcacb742574ffa3ced.jpg)
我之前发布了一个问题并没有太多运气,我希望清除第二个下拉列表的内容并重新填充下拉列表,具体取决于第一个下拉列表中的值.
我有以下选择框,如下所示:
<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方法中重新填充?
任何帮助将不胜感激,非常感谢提前
解决方法:
此答案提供了对代码的必要修改.
免责声明:如果没有看到确切的安装,请注意可能有多种因素导致此安装无法“按原样”运行.我不知道你的路由是如何设置的,或者你是否正在使用Firebug或其他控制台观看ajax调用,但是这应该给你构建块:
首先,更改您的php以将数组输出为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请求和返回的数据,以便您可以根据需要进行修改.祝好运!
内容总结
以上是互联网集市为您收集整理的javascript – 使用JQUERY,AJAX和PHP填充选择框全部内容,希望文章能够帮你解决javascript – 使用JQUERY,AJAX和PHP填充选择框所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。