du77887 2016-08-16 07:44
浏览 97
已采纳

如何使用ajax调用从数据库中列出bootstrap下拉项值?

I am having a Bootstrap dropdown in my HTML which when clicked should list values from postgres database through AJAX request

<div class="dropdown">
  <button class="btn btn-primary dropdown-toggle" type="button" data-toggle="dropdown">Region/Country
    <span class="caret"></span>
  </button>
  <ul class="dropdown-menu">
    <li>
      <a href="#"></a>
    </li>
  </ul>
</div>

This is my PHP service code which gets called by AJAX when the dropdown is clicked:

$result = pg_query($dbh, "SELECT country from countries");

if (!$result) {
  echo "An error occurred.
";
  exit;
}
$features = array();

while ($row = pg_fetch_array($result)) {
  $features[] = array("country" => array($row[0]));
}

$result_feature = $features;

echo json_encode($result_feature);

I had tried something like below

$(".dropdown-toggle").dropdown({
                source: function (request, response) {
                     $.ajax({
                         url: 'KFRI_Service.php',
                         dataType: 'json',//since you wait for json
                         data: {
                            'service': 'dropdown'
                        },
                         success: function(json){
                        //now when you received json, render options
                            $.each(json, function(i, option){
                                var rendered_option = '<li><a href="#">'+ option.country +'</a></li>';
                                $(rendered_option).appendTo('.dropdown-menu');
                            })
                        }
                    })

                }
            })

current dropdown

  • 写回答

2条回答 默认 最新

  • douyakan8924 2016-08-16 07:49
    关注

    Something like this:

    $.ajax({
      url: 'url',
      dataType: 'json', //since you wait for json
      success: function(json) {
        //now when you received json, render options
        $.each(json, function(i, option) {
          var rendered_option = '<li><a href="#">' + option.country + '</a></li>';
          $(rendered_option).appendTo('.dropdown-menu');
        })
      }
    })
    

    And by the way - since frontend is waiting for JSON, you don't always echo your text, for example you need to write an error message:

    if (!$result) {
      echo "An error occurred.
    ";
      exit;
    }
    

    That's bad - because on client side JQuery will try to parse JSON response and will silently fail in case of error.

    Should be done like this:

    if (!$result) {
      echo json_encode(['error' => 'An error occurred.']);
      exit;
    }
    

    Now it can easily be checked on client side:

    success: function(json){
    
      if (json.error) {
        alert(json.error);
      } else {
        // do your stuff
      }
    
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 关于#单片机#的问题,请各位专家解答!
  • ¥15 博通raid 的写入速度很高也很低
  • ¥15 目标计数模型训练过程中的问题
  • ¥100 Acess连接SQL 数据库后 不能用中文筛选
  • ¥15 用友U9Cloud的webapi
  • ¥20 电脑拓展屏桌面被莫名遮挡
  • ¥20 ensp,用局域网解决
  • ¥15 Python语言实验
  • ¥15 我每周要在投影仪优酷上自动连续播放112场电影,我每一周遥控操作一次投影仪,并使得电影永远不重复播放,请问怎样操作好呢?有那么多电影看吗?
  • ¥20 电脑重启停留在grub界面,引导出错需修复