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 :

[Fun] Casse-tête en Z-index


Sujet :

Positionnement en CSS avec z-index

  1. #1
    Membre chevronné Avatar de Er3van
    Homme Profil pro
    Architecte Logiciel
    Inscrit en
    Avril 2008
    Messages
    1 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte Logiciel
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2008
    Messages : 1 430
    Points : 2 227
    Points
    2 227
    Par défaut [Fun] Casse-tête en Z-index
    Voici un véritable casse-tête qui je l'espère à quand même une solution !


    Après les discussions récentes au sujet des z-index, j'ai voulu m'amuser un peu à tester un cadre somme toute banal, mais qui s'avère plus complexe à réaliser qu'il ne le semble à première vue.

    Mon cadre est composé de quatre barres, deux verticales ( gauche et droite ), et deux horizontales ( haut et bas ).

    L'effet que je souhaite faire, vous le connaissez sans doute :
    Je souhaite que la barre du dessus soit sous la barre gauche mais sur la barre droite, et que la barre du dessous soit sur la barre gauche mais sous la barre droite !

    Si joint un bout de code qui vous donnera une ébauche :
    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    <html>
    <head>
    	<title>Gwinevia</title>
    	<style type="text/css">
            * { 
                    margin : 0 ; 
                    padding : 0 ; 
            }
            #barH {
                    top : 20 px ;
                    height : 20 px ;
                    width : 100% ;
                    background-color : #FF5555 ;
                    position : absolute ;
                    z-index : 1 ;
            }
            #barG {
                    left : 20 px ;
                    height : 100% ;
                    width : 20 px ;
                    background-color : #777777 ;
                    position : absolute ;
                    z-index : 1 ;
            }
            #barB {
                    bottom : 20 px ;
                    height : 20 px ;
                    width : 100% ;
                    background-color : #5555FF ;
                    position : absolute ;
                    z-index : 1 ;
            }
            #barD {
                    right : 20 px ;
                    height : 100% ;
                    width : 20 px ;
                    background-color : #55FF55 ;
                    position : absolute ;
                    z-index : 1 ;
            }
            #content {
                    height : 100% ;
                    width : 100% ;
            }
            </style>
    </head>
    <body>
    	<div id="content">
    		<div id="barH"></div>
    		<div id="barG"></div>
    		<div id="barB"></div>
    		<div id="barD"></div>
    	</div>
    </body>
    </html>

    A vous de jouer

    PS : Candy, j'te met au défi ! ^^

  2. #2
    Membre habitué Avatar de pierre24
    Profil pro
    Inscrit en
    Février 2008
    Messages
    391
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 391
    Points : 160
    Points
    160
    Par défaut
    En faisant jouer la propriété "z-index", ca ne marche pas !?

  3. #3
    Membre chevronné Avatar de Er3van
    Homme Profil pro
    Architecte Logiciel
    Inscrit en
    Avril 2008
    Messages
    1 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte Logiciel
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2008
    Messages : 1 430
    Points : 2 227
    Points
    2 227
    Par défaut
    Surement, mais comment ??? C'est bien ça toute la question ^^

  4. #4
    Membre habitué Avatar de pierre24
    Profil pro
    Inscrit en
    Février 2008
    Messages
    391
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 391
    Points : 160
    Points
    160
    Par défaut
    tout simplement en faisant varier la vauleur : -1,1,2,3...non ???

  5. #5
    Membre chevronné Avatar de Er3van
    Homme Profil pro
    Architecte Logiciel
    Inscrit en
    Avril 2008
    Messages
    1 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte Logiciel
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2008
    Messages : 1 430
    Points : 2 227
    Points
    2 227
    Par défaut
    Quoi, faire varier la valeur ????? Je n'y avais pas pensé !!!!





    .....

    Essaye, constate, et si tu trouve une solution qui marche, poste !

  6. #6
    Membre actif Avatar de copin
    Homme Profil pro
    Webmaster
    Inscrit en
    Mai 2005
    Messages
    231
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 231
    Points : 244
    Points
    244
    Par défaut
    Blop!!

    Une solution qui fonctionne mais qui ne doit pas etre la meilleure...

    Divisé un div en deux div différents et faire varier le Z-index

    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
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
     
    <html>
    <head>
    	<title>Gwinevia</title>
    	<style type="text/css">
    	* { 
    		margin : 0 ; 
    		padding : 0 ; 
    	}
    	#barH {
    		top : 20 px ;
    		height : 20 px ;
    		width : 100% ;
    		background-color : #FF5555 ;
    		position : absolute ;
    		z-index : 5 ;
    	}
    	#barG {
    		left : 20 px ;
    		top: 50%;
    		height : 50% ;
    		width : 20 px ;
    		background-color : #777777 ;
    		position : absolute ;
    		z-index : 1 ;
    	}
    	#barG2 {
    		left : 20 px ;
    		height : 50% ;
    		width : 20 px ;
    		background-color : #777777 ;
    		position : absolute ;
    		z-index : 6 ;
    	}
    	#barB {
    		bottom : 20 px ;
    		height : 20 px ;
    		width : 100% ;
    		background-color : #5555FF ;
    		position : absolute ;
    		z-index : 1 ;
    	}
    	#barD {
    		right : 20 px ;
    		height : 100% ;
    		width : 20 px ;
    		background-color : #55FF55 ;
    		position : absolute ;
    		z-index : 4 ;
    	}
    	#content {
    		height : 100% ;
    		width : 100% ;
    	}
    	</style>
    </head>
    <body>
    	<div id="content">
    		<div id="barH"></div>
    		<div id="barG"></div>
    		<div id="barG2"></div>
    		<div id="barB"></div>
    		<div id="barD"></div>
    	</div>
    </body>
    </html>
    J'avoue! Ca fait preque honte de poster ça... Mais t'as le résultat...

  7. #7
    Membre chevronné Avatar de Er3van
    Homme Profil pro
    Architecte Logiciel
    Inscrit en
    Avril 2008
    Messages
    1 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte Logiciel
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2008
    Messages : 1 430
    Points : 2 227
    Points
    2 227
    Par défaut
    Oui, dans ce cas ça marche, mais dans ce cas tu n'a plus 4, mais 5 barres

    Mais ce n'est pas tant le résultat que je recherche ( d'où l'icône [Fun] ), plutôt une approche qui résoudrait le problème sans changer les données de celui-ci ^^'

    Pas si simple hein ?

    Et Candy, où elle est ? ^^


    PS : Sinon l'idée était bonne, un autre idée de ce type était de mettre un carré 20*20 à l'emplacement du coin, et que celui-ci ait la couleur de la barre qui va bien

  8. #8
    Membre émérite Avatar de Erwan31
    Profil pro
    Inscrit en
    Février 2008
    Messages
    2 177
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 2 177
    Points : 2 444
    Points
    2 444
    Par défaut
    Citation Envoyé par Er3van Voir le message
    Et Candy, où elle est ? ^^
    Elle bosse sur son site
    Mais c'est vrai que Candy sait si bien le faire

  9. #9
    Membre émérite
    Avatar de Candygirl
    Femme Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 912
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 52
    Localisation : Suisse

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 912
    Points : 2 907
    Points
    2 907
    Par défaut
    Je propose:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    	#barD:before {
    		width:20px;
    		height:20px;
    		display:block;
    		background-color:#FF5555;
    		content:" ";
    		margin-top:20px;
    	}
    Mais ça ne passe qu'à partir d'IE8 puisque les pseudo-éléments :before et :after (pourtant du css2) ne sont pas reconnus par IE7.

    EDIT: ARF!! Erwan31!!! lol

  10. #10
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    241
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 241
    Points : 267
    Points
    267
    Par défaut
    Citation Envoyé par Erwan31 Voir le message
    Elle bosse sur son site
    Mais c'est vrai que Candy sait si bien le faire
    Trop amoureux je suis

  11. #11
    Membre chevronné Avatar de Er3van
    Homme Profil pro
    Architecte Logiciel
    Inscrit en
    Avril 2008
    Messages
    1 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte Logiciel
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2008
    Messages : 1 430
    Points : 2 227
    Points
    2 227
    Par défaut
    N'empêche qu'elle a trouvé une solution... :X

    Et moi qui pensait que c'était insoluble dans l'état des choses.... :'(


    Encore bravo à Candy ! ( même si j'peux pas tester, la flemme de télécharger une béta d'IE8, j'te fais pleinement confiance ^^ )

  12. #12
    Membre émérite Avatar de Erwan31
    Profil pro
    Inscrit en
    Février 2008
    Messages
    2 177
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 2 177
    Points : 2 444
    Points
    2 444
    Par défaut
    Citation Envoyé par Candygirl Voir le message
    Mais ça ne passe qu'à partir d'IE8 puisque les pseudo-éléments :before et :after (pourtant du css2) ne sont pas reconnus par IE7.
    Il existe manifestement une solution (j'ai pas encore testé) pour IE7.

  13. #13
    Membre chevronné Avatar de Er3van
    Homme Profil pro
    Architecte Logiciel
    Inscrit en
    Avril 2008
    Messages
    1 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte Logiciel
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2008
    Messages : 1 430
    Points : 2 227
    Points
    2 227
    Par défaut
    Héhé, bon bein à vous deux vous avez trouvez une solution qui marche sur IE6, impressionant


    ( Pas le temps de tester non plus, si j'ai le temps dans la journée je vous dis )

  14. #14
    Membre émérite
    Avatar de Candygirl
    Femme Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 912
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 52
    Localisation : Suisse

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 912
    Points : 2 907
    Points
    2 907
    Par défaut
    Citation Envoyé par Erwan31 Voir le message
    Il existe manifestement une solution (j'ai pas encore testé) pour IE7.
    Merci, j'ai jeté un oeil mais n'ai pas non plus testé sérieusement.
    L'idée est intéressante; je la garde dans un coin, au chaud, en cas de besoin

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

Discussions similaires

  1. [Tableaux] Casse têtes de boucles
    Par Anduriel dans le forum Langage
    Réponses: 5
    Dernier message: 28/06/2006, 00h24
  2. requête SQL un peu casse tête
    Par hellbilly dans le forum Langage SQL
    Réponses: 4
    Dernier message: 15/12/2005, 10h03
  3. en-tête de table/index endommagée
    Par colombe dans le forum Bases de données
    Réponses: 5
    Dernier message: 08/10/2005, 11h55
  4. Classe, pile, pointeurs et casse-tête!
    Par zazaraignée dans le forum Langage
    Réponses: 6
    Dernier message: 26/09/2005, 16h57
  5. casse-tête excel
    Par gregius dans le forum Access
    Réponses: 2
    Dernier message: 21/09/2005, 16h38

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