Mysql
 sql >> Base de données >  >> RDS >> Mysql

Twitter bootstrap typeahead renvoie plusieurs valeurs et remplit la zone d'édition

Si je vous comprends bien, vous obtenez des résultats mais vous ne parvenez pas à remplir les champs de saisie. Bien que je n'utilise pas Twitter Bootstrap, je fais quelque chose de très similaire avec la fonction de saisie semi-automatique de jQuery. Le code ci-dessous n'a pas été testé et vous devrez bien sûr le modifier par vous-même, mais nous espérons qu'il vous sera utile.

Voir cette jsFiddle démo pour quelque chose de similaire.

PHP

$array = array();
while ($row = mysql_fetch_assoc($sql)) {
    array_push($array,array('ContactName'=>$row['ContactName'],'Telephone'=>$row['Telephone'],'Email'=>$row['Email']));
}
echo json_encode($array);


Vous pouvez vérifier ce qui est renvoyé en saisissant manuellement l'URL (ex :votresite/Client.php?query=SomeContactName). Vous devriez voir quelque chose de semblable à ceci :

[{"ContactName":"Some Contact","Telephone":"5555555555","Email":"[email protected]"},
 {"ContactName":"Some Other Contact","Telephone":"5555555555","Email":"[email protected]"}]


HTML/Javascript

<script>
    $('input.typeahead').typeahead({
        source: function (query, process) {
            $.ajax({
                url: 'Customer.php',
                type: 'POST',
                dataType: 'JSON',
                // data: 'query=' + query,
                data: 'query=' + $('#contactName').val(),
                success: function(data)
                {
                    var results = data.map(function(item) {
                        var someItem = { contactname: item.ContactName, telephone: item.Telephone, email: item.Email };
                        return JSON.stringify(someItem.contactname);
                    });
                    return process(results);
                }
            });
        },
        minLength: 1,
        updater: function(item) {
            // This may need some tweaks as it has not been tested
            var obj = JSON.parse(item);
            return item;
        }
    });
</script>

Voici quelques autres articles que vous voudrez peut-être consulter Comment renvoyer la réponse d'un AJAX appeler ? et Format de résultat Bootstrap typeahead ajax - Exemple