自动完成中的数组未显示任何内容

时间:2014-10-02 06:56:26

标签: javascript php jquery mysql arrays

这是我的jQuery自动完成代码:

PHP代码:

$query = "SELECT * FROM users";
$users = db::getRecords($query);

$usernames = Array();
foreach ($users as $user) 
{
    $username[] = '"'.$user['username'].'"';
}

数组是关联的。

JS:

$("#username").autocomplete({

    source: [<?php  echo join(',', $usernames); ?>],   
    select: function(event, ui) {

    }
});

此数组$user未转换为JavaScript数组。当我输入用户名输入时没有任何反应。如何用PHP数组定义源代码?

1 个答案:

答案 0 :(得分:1)

如果你在同一页面,我建议你这样做。

在PHP中:

$username = array();
$query = "SELECT * FROM users";
$users = db::getRecords($query);
foreach ($users as $user) {
    $username[] = array('id' => $user['id'], 'username' => $user['username'], 'label' => $user['username']);
}

$username = json_encode($username);

然后在JS:

$("#username").autocomplete({
    source: <?php echo $username; ?>,   
    select: function(event, ui) {
        alert(ui.item.id); // alets that user id
    }
});

但它强烈建议将PHP分开,这样你只需要在PHP中使用echo json_encode($data)

然后使用source: 'path/to/phpfile.php'