28172 sujets

CSS et mise en forme, CSS3

bonsoir à tous,

Pour les connectés permanents, c'est encore moi Smiley confused . Quand je suis dans un projet je ne lache pas tant que je n'ai pas fini Smiley ravi .

J'ai une div "article" qui contient un texte. La div est en height 100% et prends donc la taille du texte.
J'ai inclus un code javascript qui masque une partie du texte et qui l'affiche au clic d'un lien. Même si le texte ne s'affiche pas la div prends la taille de l'ensemble et j'aimerais que la div prenne la taille de ce qui est affiché uniquement. j'ai testé plusieurs choses mais rien ne fonctionne. Peut-être avec un overflow ? Je précise que je viens de passer les 5 dernières heures à lire le tuto sur le javascript du site du zéro et que mes connaissances sont donc encore très limitées.

<span class="article">
<h3>Les chacals miteux</h3>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod non, mi. Proin porttitor, orci nec nonummy molestie, enim est eleifend mi, non fermentum diam nisl sit amet erat. Duis semper. Duis arcu massa, scelerisque vitae, consequat in, pretium a, enim. Pellentesque congue. Ut in risus volutpat libero pharetra tempor. Cras vestibulum bibendum augue. Praesent egestas leo in pede. Praesent blandit odio eu enim. Pellentesque sed dui ut augue blandit sodales. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aliquam nibh. Mauris ac mauris sed pede pellentesque fermentum.
<span class="bouton" id="bouton_texte" onclick="javascript:afficher_cacher('texte');"></span>
<div id="texte" class="texte">
<p> Maecenas adipiscing ante non diam sodales hendrerit. Ut velit mauris, egestas sed, gravida nec, ornare ut, mi. Aenean ut orci vel massa suscipit pulvinar. Nulla sollicitudin. Fusce varius, ligula non tempus aliquam, nunc turpis ullamcorper nibh, in tempus sapien eros vitae ligula. Pellentesque rhoncus nunc et augue. Integer id felis. Curabitur aliquet pellentesque diam. Integer quis metus vitae elit lobortis egestas. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Morbi vel erat non mauris convallis vehicula. Nulla et sapien. Integer tortor tellus, aliquam faucibus, convallis id, congue eu, quam. Mauris ullamcorper felis vitae erat. Proin feugiat, augue non elementum posuere, metus purus iaculis lectus, et tristique ligula justo vitae magna. Aliquam convallis sollicitudin purus. Praesent aliquam, enim at fermentum mollis, ligula massa adipiscing nisl, ac euismod nibh nisl eu lectus. Fusce vulputate sem at sapien. Vivamus leo. Aliquam euismod libero eu enim. Nulla nec felis sed leo placerat imperdiet. Aenean suscipit nulla in justo. Suspendisse cursus rutrum augue. Nulla tincidunt tincidunt mi. Curabitur iaculis, lorem vel rhoncus faucibus, felis magna fermentum augue, et ultricies lacus lorem varius purus. Curabitur eu amet.
</div></span>


.article
{
	background-color: #DBAC45;
	display: block;
	margin: 2%;
	height:100%;
	margin-top: 2%;
	padding: 2%;
	padding-left: 3.5%;
	padding-right: 3.5%;
	vertical-align: middle;
	font-weight: bold;
	text-align: justify;
	-moz-border-radius: 5px; /* coins arrondis firefox */
	-webkit-border-radius:5px; /* coins arrondis chrome */
	border-radius:15px; /* coins arrondis IE */
	-moz-box-shadow: 5px 5px 8px #663E10;	
}

.article img {padding-right: 3%; vertical-align: middle;}

.article p {text-indent: 50px;}

.article p:first-letter {font-size: 1.5em; font-weight: bolder;}


function afficher_cacher(id)
{
        if(document.getElementById(id).style.visibility=="hidden")
        {
                document.getElementById(id).style.visibility="visible";
                document.getElementById('bouton_'+id).innerHTML='Masquer';
        }
        else
        {
                document.getElementById(id).style.visibility="hidden";
                document.getElementById('bouton_'+id).innerHTML='Suite';
        }
        return true;
}


D'avance merci
Modifié par Justaman (21 Jan 2011 - 22:32)
j'ai modifié le CSS en ajoutant :


max-height: 300px;
overflow: hidden;


De cette manière, mon code est caché, il faudrait que lors du clic sur "suite", ces propriété disparaissent, mais malgré mes tentatives je n'y arrive pas.
Modifié par Justaman (21 Jan 2011 - 22:31)
Hello !

Hum, "height : 100%" ne veut pas dire que ta div va prendre, en hauteur, la taille de ton contenu, mais qu'elle va utiliser toute la hauteur disponible (si je ne dis pas de bêtise).

Ensuite, lors du clique sur ton lien, tu as plusieurs possibilités :

_Cacher / Rendre visible le texte (grâce à display),
_Remplir / Vider la div contenant le texte (InnerHTML, replace(), removeChild()...).
Bonjour,

Span élément en ligne, H3 élément en bloc = incompatible. (mais bon c'est tolérant le Html)

Visibility, n'est pas display ..... (je te laisse creuser c'est comme ca qu'on apprend).
Modifié par rs459 (22 Jan 2011 - 19:05)