dousuize3082 2017-04-04 15:14
浏览 75
已采纳

将php数组转换为js selectpicker数组格式

This is how I build sql data and send back to ajax call:

    (...)
    $sql = "SELECT id_option FROM options WHERE id_win = '{$id_win}'";
    $result = mysqli_query($conn, $sql);
    $rows =  array();
    while ($row = mysqli_fetch_array($result)) {
      $rows[] =  $row;
    }

    $data["win_data"] = $rows;
    echo json_encode($data);

This is my ajax function to get options for selectpicker from DB:

$.ajax({
  type: "POST",
  url: ...,
  data: ...,
  dataType: "json",
  success: function(data)   {       
    $("#id_win").selectpicker("val", data.win_data);
   // $("#id_win").selectpicker("val", [1,3];
  }
});

data.win_data variable should be: [1,3]

but if I do: console.log(JSON.stringify(data.win_data)); I get:

[{"0":"1","id_option":"1"},{"0":"3","id_option":"3"}]

What is the simplest way to get proper format array for selectpicker?

  • 写回答

2条回答 默认 最新

  • duai4379 2017-04-04 15:23
    关注

    It is because $row is an array. Look: https://secure.php.net/manual/pt_BR/mysqli-result.fetch-array.php

    You have to use like this:

        (...)
        $sql = "SELECT id_option FROM options WHERE id_win = '{$id_win}'";
        $result = mysqli_query($conn, $sql);
        $rows =  array();
        while ($row = mysqli_fetch_array($result)) {
          $rows[] =  $row['id_option'];
        }
    
        $data["win_data"] = $rows;
        echo json_encode($data);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?