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 :

Autocompletion, passer de prototype à jquery


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Avril 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2008
    Messages : 32
    Par défaut Autocompletion, passer de prototype à jquery
    Bonjour à tous,
    Voila j'utilise pour mon application struts, ibatis, j'ai récemment intégré DWR pour permettre l'auto complétion sur des champs de code postaux.
    Mon auto complétion marche nickel, sauf que j'utilise prototype pour celle-ci, ce qui me fait planter certaines autres fonctionnalités car incompatible avec jquery (que j'utilise dans mon template).
    J'ai donc cherché et trouvé qu'il existe une librairie sous jquery qui permette de faire ce que je veux aussi, ce qui me permettrait de corriger mon problème d'incompatibilité....
    Sauf que, j'arrive pas à l'implémenter ! C'est donc là que j'ai besoin de votre aide

    Je vous montre ce que j'ai pour l'instant :

    ma jsp, ou l'on tape un code postal dans "zipcode", affiche la liste des propositions dans "zipcodelist" et complète la ville "town" lorsqu'on en sélectionne une
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <script type='text/javascript' src='<%= request.getContextPath()+ "/dwr/interface/AddressDWRFacade.js"%>'></script>
    <script type='text/javascript' src='<%= request.getContextPath()+ "/dwr/engine.js" %>' ></script>
    <script type='text/javascript' src='<%= request.getContextPath()+ "/dwr/util.js" %>' ></script>
    <script type='text/javascript' src='<%= request.getContextPath()+ "/custom/script/module/autocomplete/prototype/prototype.js"%>'></script>
    <script type='text/javascript' src='<%= request.getContextPath()+ "/custom/script/module/autocomplete/script.aculo.us/controls.js"%>'></script>
    <script type='text/javascript' src='<%= request.getContextPath()+ "/custom/script/module/autocomplete/script.aculo.us/effects.js"%>'></script>
    <script type='text/javascript' src='<%= request.getContextPath()+ "/custom/script/module/autocomplete/autocomplete.js"%>'></script>
     
    <script type='text/javascript' src='<%= request.getContextPath()+ "/custom/script/module/autocomplete/jquery.autocomplete.js"%>'></script>
     
    <html:text name="ContactForm" property="address.zipcode"  size="10" maxlength="32" styleId="zipcode" onblur="confirmZipcode();" />
    <html:img page="/custom/script/images/loading.gif" border="0" alt="Loading" styleId="loadingZipcode" width="18" height="18" style="display: none ;" />
    <div id="zipcodeList" class="auto_complete" style="position: relative;"></div>
    <jsp:include flush="true" page="/custom/script/module/event/townParam.jsp"></jsp:include>
    le fichier paramTown avec le code javascript
    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
    36
     
    function updateZipcode<%= param %>List(autocompleter, token) 
    	{
    		document.getElementById('loadingZipcode<%= param %>').style.display = 'inline' ;
    	 	AddressDWRFacade.getAllTownsWithZipcode(token, function(data) { autocompleter.setChoices(data) ; 
    	 	document.getElementById('loadingZipcode<%= param %>').style.display = 'none' ; });
    	}
     
    	function zipcode<%= param %>ValueSelector(tag)
    	{	
    		return tag.zipcode + " " + tag.town + " " + tag.id ;
    	}
     
    	function confirmZipcode<%= param %>() 
    	{
    		document.getElementById('loadingZipcode<%= param %>').style.display = 'inline' ;
     
    		var searchString = DWRUtil.getValue('zipcode<%= param %>');
    		if(searchString.lastIndexOf(' ') == -1 )
    			AddressDWRFacade.getTownWithZipcode(searchString,fillTown<%= param %>);
    		else
    			AddressDWRFacade.getTownWithId(searchString.substr(searchString.lastIndexOf(' ')+1, searchString.length),fillTown<%= param %>);
    	}
     
    	function fillTown<%= param %>(aTown) 
    	{
    		if(aTown != null)
    		{
    			document.getElementById('zipcode<%= param %>').value = aTown.zipcode ;
    			document.getElementById('town<%= param %>').value = aTown.town ;
    		}
     
    		document.getElementById('loadingZipcode<%= param %>').style.display = 'none' ;		
    	}
     
    	new Autocompleter.DWR('zipcode<%= param %>', 'zipcode<%= param %>List', updateZipcode<%= param %>List,{ valueSelector: zipcode<%= param %>ValueSelector, partialChars: 0});
    si quelqu'un peut m'aider, merci
    si j'ai pas été assez précis, hésitez pas....

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    j'utilise prototype pour celle-ci, ce qui me fait planter certaines autres fonctionnalités car incompatible avec jquery
    Prototype et jQuery sont parfaitement compatibles, il suffit juste de préciser à jQuery que tu utilises Prototype :
    et utiliser la syntaxe jquery(...) au lieu de $(...).
    Voir ici.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Avril 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2008
    Messages : 32
    Par défaut
    oui j'avais essayé ça...
    sauf que ca me fait des erreurs de ce type un peu partout dans les script prototype que j'utilise (en ayant bien remplacer les $() par jQuery() pour les parties concernées

    Erreur*: $ is not a function
    Fichier Source*: http://localhost:8080/eventmanager/c...e/prototype.js
    Ligne*: 1510
    Erreur*: $ is not a function
    Fichier Source*: http://localhost:8080/eventmanager/c...us/controls.js
    Ligne*: 40

    **** update
    ok en fait pas besoin de mettre le no-conflict comme prototype est chargé après, juste besoin de remplacer $()
    tout marche....mais bon j'aurais quand même préféré utiliser aussi jquery pour l'automplete... tant pis !
    du coup ce qui ne marchait plus avant remarche (logique), mais plus l'autocomplétion

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 13/09/2008, 11h49
  2. [Prototype/JQuery]debuter avec ajax
    Par kanabzh29 dans le forum jQuery
    Réponses: 3
    Dernier message: 04/09/2008, 09h57
  3. [Prototype/JQuery] tableau avec ajax
    Par friedamichelle dans le forum jQuery
    Réponses: 3
    Dernier message: 26/08/2008, 16h57
  4. [Prototype/JQuery] création d'un t'chat
    Par joa_tcherno dans le forum jQuery
    Réponses: 4
    Dernier message: 10/03/2008, 14h42
  5. Réponses: 3
    Dernier message: 07/01/2008, 10h09

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