IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

jQuery Discussion :

UI Autocomplete : mettre en évidence les caractères tapés


Sujet :

jQuery

  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    402
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2010
    Messages : 402
    Par défaut UI Autocomplete : mettre en évidence les caractères tapés
    Bonjour,

    J'utilise l'UI autocomplete avec le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
     
    <script type="text/javascript">
     
    $(function() {
     
                $( "#state" ).autocomplete({
                    source: "dev2_search_autocomplete.php",
                    minLength: 2,
     
     
    				select: function (event, ui) {
    					$('#state_id').val(ui.item.id);
                    }
                });
     
     
            });
     
     
    </script>
     
     
    </head>
     
    <body>
     
    <form action ="" method="POST">
     
    <div class="ui-widget">
       <label for="state">state </label>
       <input type="text" id="state" name="state" style="width:850px; height:20px;"/> 
       <input type="hidden" id="state_id" name="state_id" /> 
       <input type="submit" name="submitBtn" value="ok" />
    </div>
    </form>
    Le système fonctionne. Je souhaiterais savoir s'il est faisable de l'enrichir en rendant possible la mise en évidence des caractères tapés (par du gras par ex), ceci dans liste des items proposés. Par ex si je tape "ra", il me serait proposé :
    radin
    parade
    etc

    Est-possible de gérer cette fonctionnalité en jquery ? Merci.

  2. #2
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    avec un replace au moyen d'une expression régulière qui entoure les caractères tapes avec <b></b>
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  3. #3
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    402
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2010
    Messages : 402
    Par défaut
    Merci de votre réponse. La solution proposée passe-t-elle par du JavaScript ou par du Php ? La chaine à traiter est du style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $fetch = mysql_query("SELECT * FROM livre where titre like '%" . mysql_real_escape_string($_GET['term']) . "%'");
    		while ($row = mysql_fetch_array($fetch, MYSQL_ASSOC)) {
    			$row_array['value'] = $row['titre'];//chaine à traiter
    Merci de votre aide.

  4. #4
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    402
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2010
    Messages : 402
    Par défaut
    Bonjour,

    Pensant que la solution à mon problème passait par Php, j'avais posté sur le forum Php adapté. Finalement, grâce à "Djakisback", j'ai appris que la solution passait en fait par jquery. Pour ceux qui souhaitent ajouter la "surbrillance" dans l'autocomplete ui, voici le code à ajouter à la suite du code principal :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    //pour la gestion de la surbrillance
    $.ui.autocomplete.prototype._renderItem = function (ul, item) {
                item.label = item.label.replace(new RegExp("(?![^&;]+;)(?!<[^<>]*)(" + $.ui.autocomplete.escapeRegex(this.term) + ")(?![^<>]*>)(?![^&;]+;)", "gi"), "<strong>$1</strong>");
                return $("<li></li>")
                        .data("item.autocomplete", item)
                        .append("<a>" + item.label + "</a>")
                        .appendTo(ul);
            };

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 2
    Dernier message: 17/03/2010, 14h30
  2. Réponses: 12
    Dernier message: 25/06/2009, 19h08
  3. Réponses: 12
    Dernier message: 03/03/2009, 09h01
  4. Réponses: 1
    Dernier message: 21/05/2008, 08h38
  5. [Oracle] Mettre en MAJ les caractères spéciaux
    Par Egware dans le forum Langage SQL
    Réponses: 1
    Dernier message: 10/03/2006, 18h18

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo