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

Mise en page CSS Discussion :

Problème de dimensionnement de div


Sujet :

Dimensionnement en CSS

  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2004
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Janvier 2004
    Messages : 61
    Par défaut Problème de dimensionnement de div
    Bonjour,

    Je rencontre un petit problème de dimensionnement d'un div.
    Voici le code HTML:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    <div id="contenu">
    	<div id="contphotos">
    		<div class="itemgalerie">
    			une image et du blabla sur plusieurs lignes
    		</div>
    		<div class="itemgalerie">
    			une image et du blabla sur plusieurs lignes
    		</div>
    		<div class="itemgalerie">
    			une image et du blabla sur plusieurs lignes
    		</div>
    	</div>
    </div>
    Et voici le CSS :
    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
     
    div#contenu {
    	float:left;
    	min-height:500px;
    	width:75%;
    	background-image:url(img_tmp/fond_contenu.jpg);
    	color:#FDFDD4;
    	font-family:Courier new;
    	font-size:14pt;
    	font-weight:bold;
    	letter-spacing:-0.25pt;
    	}
    div#contphotos {
    	width:90%;
    	margin-top:5%;
    	margin-left:5%;
    	margin-right:5%;
    	margin-bottom:5%;
    	color:#000000;
    	background-color:#FFFFBE;
    	border-style:groove;
    	border-width:medium;
    	border-color:#3033EC;	
    	padding-top:10px;
    	padding-bottom:10px;
    	}
    div.itemgalerie {
    	float:left;
    	margin-right:20px;
    	margin-left:20px;
    	text-align:center;
    	width:27.5%;
    	}
    Je souhaite que le div "contphotos" contienne les div "itemgalerie", ce qui devrait se traduire par un fond de couleur #FFFFBE englobant les div "itemgalerie". L'effet désiré est là avec IE, mais sur Opéra et FF, il n'y a qu'une bande horizontale (à cause des paddings et du width), sur laquelle "mordent" un peu les div "itemgalerie". Si je force l'attribut height (par exemple, à 300px), j'obtiens bien un rectangle de couleur #FFFFBE sur lequel sont les div "itemgalerie". Cependant, comme le nombre de ces div n'est pas défini à l'avance (générés à partir d'une base de données), et donc il peut y en avoir plusieurs lignes, je ne peux pas définir une fois pour toutes le height (ce serait trop facile...).

    Je ne sais pas si je me suis fait comprendre, merci de votre aide...

  2. #2
    Membre Expert
    Avatar de trotters213
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 571
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Gard (Languedoc Roussillon)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 571
    Par défaut

    si c'est généré par une BD c'est que tu as un langage dynamique derièrre comme PHP ou ASP donc tu savoir avant l'affichage le nombre de ligne qu'il va y avoir. Tu multiplies ce nombre avec une valeur et tu la places à ta hauteur.

    PS :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    margin-top:5%;
    margin-left:5%;
    margin-right:5%;
    margin-bottom:5%;
    équivautet
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    padding-top:10px;
    padding-bottom:10px;
    équivaut(si on considère que right et left sont à zéro).
    De même pour
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    margin-right:20px;
    margin-left:20px;
    qui est la même chose que et pour finir
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    border-style:groove;
    border-width:medium;
    border-color:#3033EC;
    pareil que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    border:groove medium #3033EC;

  3. #3
    Membre confirmé
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2004
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Janvier 2004
    Messages : 61
    Par défaut
    Merci pour cette suggestion. A vrai dire, j'y avais songé, mais je me demandais s'il existait une méthode plus "automatique" (genre un attribut que j'aurais oublié de préciser). Enfin, s'il n'y a rien d'autre, je m'en contenterai.



    P.S. : je ne mets pas encore "Résolu", si quelqu'un a une autre idée...

  4. #4
    Inactif  
    Avatar de Kerod
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    11 672
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 11 672
    Par défaut
    Il y a aussi la solution du display:inline mais bon

  5. #5
    Membre confirmé
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2004
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Janvier 2004
    Messages : 61
    Par défaut
    Bon, avec le display:inline, je n'ai pas le résultat souhaité (peut-être qu je ne m'en sers pas bien). Je vais donc plutôt utiliser la solution de trotters213.

    Je continue à m'interroger sur le fait que IE fasse ce que je veux et pas FF (d'habitude c'est l'inverse )

  6. #6
    Rédacteur
    Avatar de MasterOfChakhaL
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2004
    Messages
    2 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2004
    Messages : 2 147
    Par défaut
    Salut,

    tes itemsgalleries sont en float et sont donc sortis du flux de ta page, par conséquent ils ne sont pas pris en compte pour calculer la hauteur de leur parent...

    un élément avec la propriété clear refuse de se coller à un élément en float et passe donc a la ligne tout en restant dans le flux...
    Voilà quelque chose d'interessant à exploiter dans ta situation...

    précision sur les valeurs possibles de la propriété clear:
    -left: refuse les éléments flottants à sa gauche (les float right)
    -right: pareil mais de l'autre coté
    -both: se place forcément sous les éléments flottants...

    je te suggère ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <div id="contenu">
    	<div id="contphotos">
    		<div class="itemgalerie">
    			une image et du blabla sur plusieurs lignes
    		</div>
    		<div class="itemgalerie">
    			une image et du blabla sur plusieurs lignes
    		</div>
    		<div class="itemgalerie">
    			une image et du blabla sur plusieurs lignes
    		</div>
    		<div class="spacer">&nbsp;</div>
    	</div>
    </div>
    et le css correspondant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    .spacer {
    	clear: both !important;
    	float: none !important;
    	border: none !important;
    	height: 1px !important;
    	line-height: 1px !important;
    	font-size: 1px !important;
    	padding: 0 !important;
    	margin: 0 0 -1px 0 !important;
     
    	visibility: hidden !important;
    }
    les !important sont là pour éviter d'éventuelles interférences avec d'autres règles...

    normalement, le résultat devrait être invisible et identique sur tous les navigateurs courants (testé et approuvé sous ie6 et opéra 9)
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    N'oubliez pas de cliquer sur quand votre question à trouvé une solution.

    Si vous n'avez pas encore lu les règles du club, mieux vaut tard que jamais!

  7. #7
    Membre confirmé
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2004
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Janvier 2004
    Messages : 61
    Par défaut
    J'ai testé, ça marche !

    C'est exactement ce que je cherchais, !!!

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

Discussions similaires

  1. [AJAX] dimensionnement div contenu et Ajax
    Par MrFurious dans le forum AJAX
    Réponses: 10
    Dernier message: 16/05/2011, 21h55
  2. dimensionnement de ma page avec div
    Par paolo2002 dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 29/04/2008, 13h56
  3. Problème pour dimensionner une div
    Par DaXou45 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 16/11/2007, 13h02
  4. [CSS & MSIE6] Dimensionnement de div
    Par Floréal dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 03/04/2007, 09h40
  5. Re-dimensionnement automatique de composants
    Par ludo_7 dans le forum C++Builder
    Réponses: 10
    Dernier message: 16/05/2002, 16h35

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