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

Posted

技术标签:

【中文标题】使用 JQUERY、AJAX 和 PHP 填充选择框【英文标题】:Populating a select box using JQUERY, AJAX and PHP 【发布时间】: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 调用的成功方法中重新填充?

任何帮助将不胜感激,在此先感谢

【问题讨论】:

感谢您的代码 .. 它在我的网站上运行 .... 【参考方案1】:

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

免责声明:在没有看到确切安装的情况下,请注意可能有多种因素导致它在您的安装中无法“按原样”运行。我不知道您的路线是如何设置的,或者您是否使用 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 请求和返回的数据,以便您可以进行适当的修改。祝你好运!

【讨论】:

谢谢,我会试一试 - 我还在学习,所以我不太擅长在 PHP 和 JS 之间传递数据# 除了最后一行之外,您的所有代码似乎都可以工作 - 我已经更新了我的问题以包含数组输出 - 你能告诉我这一行应该是什么:$('#emptyDropdown'). append('');如果数组如下: ( [0] => Array ( [ModelName] => R8 V6 Twin Turbo [ModelID] => 19 ) [1] => Array ( [ModelName] => A6 Hatchback [ModelID] => 107)) @TotalNewbie - 我已经修改了代码。此外,您可能希望在 $.each 函数中放置 console.log(d); 以确保您得到预期的结果。如果它仍然不起作用,请添加 console.log 并在此处使用控制台日志的内容发表评论,以便我们查看您的数据结构。 您好,我现在确实可以正常工作了,非常感谢 - 我的一个小错字非常感谢所有帮助 @cale_b - 我正在开发我网站的设置页面。在表单中,有一些值将在页面加载时从数据库中自动填充。我只使用 PHP 以及 ajax 和 PHP 来做到这一点。在 PHP 中,值是在页面加载时加载的,但在 ajax 中,值仅在页面加载后才会反映,因此我可以看到 2-3 毫秒的默认值。请建议使用哪种方式更好?

以上是关于使用 JQUERY、AJAX 和 PHP 填充选择框的主要内容,如果未能解决你的问题,请参考以下文章

从服务器目录填充选择 PHP jQuery AJAX

jQuery 使用 jQuery ajax json、php 将项目填充到 Select 中

如何使用 Ajax 和 Jquery 从 PHP 数据库中提取信息,并使用该信息填充元素?

PHP-AJAX:如何通过 php/json 数组从查询中填充 jquery 数据表

使用 AJAX、PHP 和 MySQL 链式填充 HTML 选择框

jquery如何进行多个ajax调用[重复]