簡體   English   中英

Bootstrap Typeahead:以json的形式從數據庫獲取數據

[英]Bootstrap Typeahead: getting data from database as json

我遇到了引導程序提前輸入以從MySQL數據庫以json數組形式返回數據的問題。

這是我到目前為止的內容:

$('.typeahead').typeahead({
    items: 5,
    source: function (query, process) {
        $.ajax({
            url: 'typeahead.php',
            type: 'POST',
            dataType: 'JSON',
            data: 'query=' + query,
            success: function(data) {
                process(data);
            }
        });
    },
    highlighter: function(data) {
        // decode JSON data and return it here
    },
    updater: function(data) {
        console.log("CLICKED!");
    },
});

這是PHP文件:

$search_for = $_POST['query'];
$return = array();

$stmt = $cxn->prepare('SELECT username, display_name FROM users WHERE username LIKE concat("%", ?, "%") OR display_name LIKE concat("%", ?, "%")');
$stmt->bind_param('ss', $search_for, $search_for);
$stmt->execute();
$result = $stmt->get_result();

while (($row = $result->fetch_assoc())) {
    array_push($return, array($row['username'], $row['display_name']));
}

$json = json_encode($return);
echo $json;

這是它返回的JSON:

[["username","Display Name"],["username2","Display Name 2"]]

但是,當我測試提前輸入時,此代碼不起作用。 它在控制台中給出以下錯誤:

http://i.imgur.com/xT8CV2b.png

因此,我的問題是,如何正確地從數據庫中獲取多個數據並將其放入json數組中?

代替:

while (($row = $result->fetch_assoc())) {
    array_push($return, array($row['username'], $row['display_name']));
}

采用:

while (($row = $result->fetch_assoc())) {
    if (isset($row)) $return[] = $row;
}

JavaScript文件:

function maketypeahead() {
    $(document).ready(function() {
       $('input.typeahead').typeahead({
         items: 5,
         source: function (query, process) {
            $.ajax({
              url: 'typeahead.php',
              type: 'POST',
              dataType: 'JSON',
              data: 'query=' + query,
              success: function(data) {
                console.log(data);
                process(data);
              }
            });
          },
          highlighter: function(item) {
         // Split JSON Array into multiple pieces of data from a database
              var parts = item.split('#'),
              html2 = '<div class="typeahead">';
              html2 += '<div class="media">'
              html2 += '<div class="media-body">';
              html2 += '<span>'+parts[0]+'</span>'+'<br><span style="font-size:7pt" >('+parts[1]+')</span>'+'</p>';
              html2 += '</div>';
              html2 += '</div>';
              return html2;
            },
        updater: function (item) {
            var parts = item.split('#');
            return parts[1];
        },
        });
      });
}

// Run typeahead function
maketypeahead();

php文件(typeahead.php):

<?php
// First you need to connect to your database
$hostname_connection = "localhost";
$database_connection = "cms_db";
$username_connection = "root";
$password_connection = "root";
$connection = mysql_connect($hostname_connection, $username_connection, $password_connection) or trigger_error(mysql_error(),E_USER_ERROR); 
mysql_select_db($database_connection, $connection);

// Select multiple pieces of data from a database
$query = "SELECT username, display_name FROM `users` ";
  if(isset($_POST['query'])){
    $query .= ' WHERE username LIKE "%'.$_POST['query'].'%"' ;
  }
$rs = mysql_query($query) or die(mysql_error());

// And put it into a json array
$return = array();  
while ($rs_db['query'] = mysql_fetch_assoc($rs)){
//
$return[] = $rs_db['query']['username'].'#'.$rs_db['query']['display_name'];    
};
$json = json_encode($return);
print_r($json);
?>

CSS文件

@charset "utf-8";
/* CSS Document */

.typeahead.dropdown-menu {
    color: #000;
    background-color: #FFFFFF;
    padding: 0;
    margin: 10px;
}
.typeahead a {
    color: #000;
    background-color: #FFFFFF;
    padding: 0;
    margin: 10px;
    vertical-align: middle;
}
.typeahead {
    padding: 0px 5px;
    min-width: 250px;
}
.typeahead.dropdown-menu {
    z-index: 200000;
}
.modal-body {
    overflow-y: inherit;
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM