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 :

Comment faire pour modifier la propriété du CSS


Sujet :

jQuery

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 098
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 098
    Points : 946
    Points
    946
    Par défaut Comment faire pour modifier la propriété du CSS
    Bonjour à tous,

    J'essaye de modifier le CSS sur un <li> mais évidemment je n'y arrive pas.

    Voici le html
    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    <ul class="ddmenu">
    <li>1</li>
    <li>2
    <ul style="display:none">
    <li>2.1</li>
    <li>2.2</li>
    </ul>
    </li>
    </ul>

    et voici le code jquery
    Code jquery : 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
    37
    38
    39
    40
     
    // JavaScript Document
    	var timeout    = 9500;
    	var closetimer = 0;
    	var ddmenuitem = 0;
     
     
    	function ddmenu_open(){
    			ddmenu_canceltimer();
    		   	ddmenu_close();
    		   	  ddmenuitem = $(this).find('ul').css('display', 'block');
    //			  ddmenuitem = $(this).find('ul').parent().css('background-image', 'none');
    //			  ddmenuitem = $(this).find('ul').parent().css('background-color', '#eeeeee');
     
    		}
     
    	function ddmenu_close(){ 
    			if(ddmenuitem){
    				ddmenuitem = ddmenuitem.css('display', 'none');
    			}
    		}
     
    	function ddmenu_timer(){
    			closetimer = window.setTimeout(ddmenu_close, timeout);
    		}
     
    		function ddmenu_canceltimer(){  
    			if(closetimer){  
    				window.clearTimeout(closetimer);
    		        closetimer = null;
    			}
    		}
     
     
    		document.onclick = ddmenu_close;
    		$(document).ready(function(){
    			$('.ddmenu > li').find('ul').css('display', 'none');
    			$('.ddmenu > li').bind('mouseover', ddmenu_open);
    		    $('.ddmenu > li').bind('mouseout',  ddmenu_timer);
    		});

    Ceci fonctionne très bien.
    Mais, par défault les <li> du premier niveau on une background-image.
    Quand je passe la souris sur le li, le sous menu se développe très bien. Mais j'aimerais que l'image de fond soit remplacé par la couleur de fond background-color:#eee; et évidemment quand le timeout est échu, que l'image de fond revienne.

    J'ai essayé de faire avec un parent(), comme vous le voyer en commentaire. Mas évidemment ca ne fonctionne pas.

    Pourriez-vous m'aider la dessus?

    Aussi, j'aimerais que le sous-menu de développe en douce. Il y a une fonction comme toogle? ou slideDown(slow)?
    Malheureusement je n'y ai aussi pas réussi, mais je vais encore regarder, mais si vous pouviez me mettre sur la piste ca serait cool.

    Merci

  2. #2
    Membre habitué Avatar de elfamine
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    113
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2011
    Messages : 113
    Points : 186
    Points
    186
    Par défaut
    en CSS normalement ca devrait faire l'affaire...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    .ddmenu{
    background-image:url('bg.png');}
     
    .ddmenu li ul{
    background-image:none!important;
    background-color:#eee;
    edit:j'ai rien dit je crois que tu cherche .stop().animate({"background-image": "img.png"}, "slow");

  3. #3
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 098
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 098
    Points : 946
    Points
    946
    Par défaut
    Heu, ben c'est en jQuery que je veux changer les propriétés du CSS...
    Pas directement dans le fichier .css

  4. #4
    Membre habitué Avatar de elfamine
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2011
    Messages
    113
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2011
    Messages : 113
    Points : 186
    Points
    186
    Par défaut
    selon la docu ici : http://api.jquery.com/animate/ à moins d'utiliser le plugin jQuery.Color() tu ne pourra pas manipuler background-color
    j'ai essayé avec fontSize pour le fun
    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
    <html>
    <head>
    <style media="screen" type="text/css">@import url("center.css");</style>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type="text/javascript"></script>
    <script type="text/javascript">
    $(document).ready(function() {
    $('.submenu').hide();
     	$('.xmenu').hover(
    		function(){	$('.submenu',this).slideDown();
    					 $('.submenu li',this).animate({fontSize: "3em"}, "slow");
    				},
    		function(){$('.submenu',this).slideUp();
    		$('.submenu li',this).animate({fontSize: "1em"}, "slow")}
    	); 
    });
    </script>
    </head>
    <body>
     
    <ul class="ddmenu">
    <li>1</li>
    <li class="xmenu">2
    <ul class="submenu">
    <li>2.1</li>
    <li>2.2</li>
    </ul>
    </li>
    </ul>
    </body>
    </html>

  5. #5
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 098
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 098
    Points : 946
    Points
    946
    Par défaut
    Ben je viens juste de trouver avec

    addClass() et removeClass() et ca marche bien. Du moins je l'espère, je suis en train de tester

    Reste a voir comment faire le slide.

    J'ai trouver

    show( 'slide', 'down', 1000 )

    Mais ca fonctionne bizarement.....

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 11/05/2009, 14h48
  2. Comment faire pour modifier une JTable
    Par jlenoir dans le forum Composants
    Réponses: 5
    Dernier message: 12/02/2007, 12h50
  3. Réponses: 4
    Dernier message: 05/01/2006, 09h01
  4. [C#] A l'aide! comment faire pour modifier un noeud?
    Par irnbru dans le forum Windows Forms
    Réponses: 12
    Dernier message: 15/11/2005, 17h41
  5. Comment faire pour modifier une ligne dans une DBGrid?
    Par Nico62 dans le forum C++Builder
    Réponses: 6
    Dernier message: 29/03/2005, 12h24

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