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 :

Faire déborder un div en width pourcentage dans un td


Sujet :

CSS

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 10
    Par défaut Faire déborder un div en width pourcentage dans un td
    Bonjour,
    Comment je peux faire pour que floatDiv apparaisse par dessus de la cellule qui le contient et prend 200% de sa taille. Elle doit rester en 25% elle aussi.

    Merci de votre aide

    Code html : 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
    <br/>
    <table style="border:1px red solid;width:100%">
    	<tr>
    		<td style="width:25%">
    			<div id="floatDiv" style="width=200%; border:1px gray solid;">
    				<table>
    					<tr>
    						<td style="width=50%">toto</td>
    						<td style="width=50%">toto</td>
    					</tr>
    				</table>
    			</div>
    		</td>
    		<td style="width:25%">cell</td>
    		<td style="width:25%">cell</td>
    		<td style="width:25%">cell</td>
    	</tr>
    </table>

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    position:absolute; ?

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 10
    Par défaut
    Si je mets le div en absolute, les 200% pour sa width se calculent par rapport au document et non pas par rapport à la cellule parente.
    Je voudrais que le div garde sa place dans la cellule mais la dépasse (2 fois sa width).
    j'espère que ma réponse est assez claire.

  4. #4
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 211
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 211
    Par défaut
    Bonjour,
    c'est quoi cette syntaxe dans l'attibut style ?
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <div id="floatDiv" style="width=200%; border:1px gray solid;">
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    #floatDiv{
      width:200%;   /* on met : et pas = */
      border:1px gray solid;
    }

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    voilà l'astuce : http://codepen.io/jreaux62/pen/kpFGv
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    		<td style="width:25%" id="floatDivtd">
    			<div id="floatDiv">
    				<table>
    					<tr>
    						<td>toto sdsdfgsdfg hd gf,kh </td>
    						<td>totoyo çuy yyktyuikl iuiçlyuil gtkluiklt ui</td>
    					</tr>
    				</table>
    			</div>
    		</td>
    Code css : 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
    td#floatDivtd { 
      vertical-align:top; /* la position par defaut est au milieu */
    }
    #floatDiv { /* on remplit la cellule avec cette div */
    	position:relative; 
    	width:100%; 
    	height:100%;
    }
    #floatDiv table {
    	position:absolute; 
    	width:200%;
    	left:-50%; /* on centre sur la cellule */
    	top:0; /* par rapport à la position qu'aurait dû avoir l'élément */
    	border:1px solid gray;
    }
    #floatDiv table td {
    	width:50%;
    }
    De fait, ce n'est pas la <div>, mais la <table> (dans la <div>) qui flotte au dessus.

  6. #6
    Membre chevronné
    Profil pro
    Chef Gérant
    Inscrit en
    Octobre 2005
    Messages
    230
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Chef Gérant
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2005
    Messages : 230
    Par défaut
    une marge négative sur le div fonctionne aussi: http://codepen.io/gc-nomade/pen/IpEfz
    Code html : 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
    <table style="border:1px red solid;width:100%">
    	<tr>
    		<td style="border:solid;width:25%">
    			<div id="floatDiv" style="width:200%; border:1px gray solid;margin-right:-100%;">
    				<table style="width:100%;">
    					<tr>
    						<td style="border:solid;width=50%">toto</td>
    						<td style="border:solid;width=50%">toto</td>
    					</tr>
    				</table>
    			</div>
    		</td>
    		<td style="border:solid;width:25%">cell</td>
    		<td style="border:solid;width:25%">cell</td>
    		<td style="border:solid;width:25%">cell</td>
    	</tr>
    </table>

Discussions similaires

  1. [FAQ] Les formulaires (partie 2) : Comment faire passer un div au dessus d'un select dans IE ?
    Par Auteur dans le forum Contributions JavaScript / AJAX
    Réponses: 6
    Dernier message: 28/11/2013, 12h08
  2. Réponses: 2
    Dernier message: 11/02/2010, 14h29
  3. Réponses: 2
    Dernier message: 30/11/2009, 09h37
  4. Faire déborder un div via un autre div
    Par gomodo dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 05/11/2008, 00h33
  5. Faire apparaitre un DIV dans une zone différente
    Par ThomasH dans le forum Mise en page CSS
    Réponses: 5
    Dernier message: 23/10/2006, 14h45

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