php - 从数据库填充多个相关的下拉列表

标签 php jquery mysql ajax

我有 2 个下拉菜单。第一个我填充了可能的大洲,并希望第二个下拉列表包含所有国家/地区,具体取决于在第一个菜单中选择的大洲。我只有 1 个带有列的 mysql 表:大陆 --> 国家。目前,即使选择了一个大洲,下拉菜单中也会显示所有大洲的所有国家/地区。感谢您的帮助! 这是我的代码:

HTML

<input type="text" class="autosuggest" id="autosuggest2" placeholder="Select Country...">
<div class="country">
<ul class="result" id="result2"></ul>
</div>
<input type="text" class="autosuggest" id="autosuggest3" placeholder="Select Area...">
<div class="area">
<ul class="result" id="result3"></ul>
</div>

jQuery/ Ajax

$(document).ready(function() { 
$('#autosuggest1').keyup(function() {
    var continent = $(this).attr('value');
    $.post('php/dropdown.php', {continent:continent}, function(data) {
        $('#result1').html(data);

        $('.result li').click(function() {
            var result_value = $(this).text();
            $('#autosuggest1').attr('value', result_value);
            $('#result1').html('');
            $('#result1').focusout('');
        });
    });
});

$('#autosuggest2').keyup(function() {
    var country = $(this).attr('value');
    $.post('php/dropdown.php', {country:country}, function(data) {
        $('#result2').html(data);

        $('.result li').click(function() {
            var result_value = $(this).text();
            $('#autosuggest2').attr('value', result_value);
            $('#result2').html('');
            $('#result2').focusout('');
        });
    });
});
});

PHP

require_once '../connect/connectdropdown.php';

if (isset($_POST['continent']) == true && empty($_POST['continent']) == false) {
$continent = mysql_real_escape_string($_POST['continent']);
$query = mysql_query("SELECT DISTINCT `continent` FROM `area` WHERE `continent`    LIKE '$continent%'");
while (($row = mysql_fetch_assoc($query)) !== false) {
    echo '<li>', $row['continent'], '</li>';
}   
}

if (isset($_POST['country']) == true && empty($_POST['country']) == false) {
$country = mysql_real_escape_string($_POST['country']);
$query = mysql_query("SELECT DISTINCT `country` FROM `area` WHERE `country` LIKE '$country%'");
while (($row = mysql_fetch_assoc($query)) !== false) {
    echo '<li>', $row['country'], '</li>';
}   
}

最佳答案

我想知道你是否还在关注这个。不管怎样,我会建议几件事:

只做一个查询,传给json,传给javascript。

PHP

require_once '../connect/connectdropdown.php';
$id=0;
$result=array();
$query = mysql_query("SELECT * FROM `area` ");
while (($row = mysql_fetch_assoc($query)) !== false) {
   $result[$id]=$row;
   $id++;
}   
echo json_encode($result);

Javascript

$(document).ready(function() { 
      var $mysqlData;
      $.post('php/dropdown.php', {continent:continent}, function(data) {

        //Json Data from server:
        alert('JSON data: '+data)
        //you can transform the data from PHP-Json to Javascript Object
        $mysqlData = jQuery.parseJSON(data)
        //now you can access your data like:
        alert ('My first continent: '+$mysqlData[0].continent+' and it\'s first country: '+$mysqlData[0].country)
      });

      $('#autosuggest1').keyup(function() {
          //Now you can use $mysqlData inside your logic
      })

      $('#autosuggest2').keyup(function() {
          //You can use $mysqlData here too
      })

});

我没有测试这段代码,可能有一些错误,但我建议你采用的逻辑。

关于php - 从数据库填充多个相关的下拉列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10698192/

相关文章:

php - 将多行从 php 页面插入到 mysql 中

php - 样式表正在加载但样式不适用于 codeigniter 的管理面板?

javascript - 根据值创建 JSON 对象

php - 注释未插入 MySQL 表中

php - Kohana - 使用 DB::query 获取所有表

用于缓存权限的 PHP 全局时间戳

php - 哪个最不密集 - 在 PHP 或 MySQL 中计算唯一时间?

javascript - 选择文件夹而不是单个文件 - 输入

javascript - set超时问题

mysql - Rails - 使用 SQL 查询获取回形针 URL