Posez votre question Signaler

[Spoiler] HTML [Résolu]

Pingson 378Messages postés 5 mai 2005Date d'inscription - Dernière réponse le 25 nov. 2011 à 17:51
Salut!

Je voudrais savoir quel est le code pour faire un spoiler comme ceci:

http://forum.hardware.fr/hardwarefr/JeuxVideo/Ouverture-facile-aides-pour-passer-niveaux-Lire-post-sujet-86813-2.htm

Mais pas sur un forum

Merci
Lire la suite 

[Spoiler] HTML »

Suggestions
40 réponses
Réponse
+30
moins plus
Voici un spoiler qui devrais bien fonctionner:

<div style="margin:20px; margin-top:5px"><div class="quotetitle"><b>Spoiler:</b> <input type="button" value="Afficher" style="width:45px;font-size:10px;margin:0px;padding:0px;" onclick="if (this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display != '') { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = '';        this.innerText = ''; this.value = 'Cacher'; } else { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = 'none'; this.innerText = ''; this.value = 'Afficher'; }" /></div><div class="quotecontent"><div style="display: none;">{TEXT}</div></div></div>


il faut juste modifier {text} par votre texte
lord-pi - 11 sept. 2010 à 14:50
Je sais pas pour vous, mais chez moi elle ne marche pas sur blogger ='(
dieurdieuf - 15 sept. 2010 à 10:47
Bonjour Lord-Pi.

Tu trouveras une illustration sur cette page.

http://dieurdieuf.blogspot.com/2009/07/attention-sur-msn.html

Voici le code utilisé.

<div style="margin: 5px 20px 20px;"><div class="quotetitle"><b>Spoiler : </b> <input value="Afficher" style="margin: 0px; padding: 0px; width: 50px; font-size: 10px;" onclick="if (this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display != '') { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = '';        this.innerText = ''; this.value = 'Cacher'; } else { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = 'none'; this.innerText = ''; this.value = 'Afficher'; }" type="button"></div><div class="quotecontent"><div style="display: none;"> <a href="http://yfrog.com/bglivemessengerj" target="_blank"><img style="width: 201px; height: 115px;" src="http://img412.imageshack.us/img412/415/livemessenger.jpg" border="0" alt="Attention" /></a>  </div></div></div>    


Il faut remplacer la partie en gras par le texte, image ou média que tu souhaites afficher en spoiler.

Bonne journée.
Mademoiselle - 25 nov. 2011 à 17:51
Salut, j'ai essayé, disons j'ai vue des spoiler avec des image?!
Ajouter un commentaire
Réponse
+10
moins plus
un peu long vos code pour ceux qui veulent plus court j'en ai 2
celui là
<div class="c1" onclick="javascript:montrer_spoiler('spoiler2')"><strong>spoiler</strong>
<script type="text/javascript">
function montrer_spoiler(value){var actual=document.getElementById(value).style.visibility;if (actual=='visible'){document.getElementById(value).style.visibility='hidden';}else{document.getElementById(value).style.visibility='visible';}} </script>
<dl style="visibility: hidden;" id="spoiler2">
<dd>texte c<br>
</dd>
</dl>  
</div> 
ou lui


<div class="c1"
 onclick="pchild=this.getElementsByTagName('p'); if(pchild[0].style.visibility!='hidden'){pchild[0].style.visibility='hidden'; pchild[0].style.height='0';}else{pchild[0].style.visibility=''; pchild[0].style.height=''}">Spoiler
<p style="">texte<br>
cach<br>
cach<br>
cach<br>
</p>
</div>
crocoscore - 31 mai 2009 à 10:35
Vous avez aussi:

Avec une case à cocher:
<div><div class="quotetitle"><input type="checkbox" value="Afficher" style="width:98%;font-size:20px;margin:0px;padding:0px;" onclick="if (this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display != '') { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = ''; this.innerText = ''; this.value = 'Cacher'; } else { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = 'none'; this.innerText = ''; this.value = 'Afficher'; }" /></div><div class="quotecontent"><div style="display: none;">

Avec un bouton:
<div><div class="quotetitle"><input type="button" value="Afficher" style="width:98%;font-size:20px;margin:0px;padding:0px;" onclick="if (this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display != '') { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = ''; this.innerText = ''; this.value = 'Cacher'; } else { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = 'none'; this.innerText = ''; this.value = 'Afficher'; }" /></div><div class="quotecontent"><div style="display: none;">

Enjoy it!
Ajouter un commentaire
Réponse
+5
moins plus
j'ai encore plus court source mon site http://bormat2.free.fr/

<div class="c1" onclick="javascript:montrer_spoiler('spoiler2')"><strong>spoiler</strong>
<script type="text/javascript">
function montrer_spoiler(value){var actual=document.getElementById(value).style.visibility;if (actual=='visible'){document.getElementById(value).style.visibility='hidden';}else{document.getElementById(value).style.visibility='visible';}} </script>
<dl style="visibility: hidden;" id="spoiler2">
<dd>texte c<br>
</dd>
</dl>
</div>

vous avez aussi des spoilesr compressable
Ajouter un commentaire
Réponse
+3
moins plus
désolé mon lien à des problème voici où il a été déplacer il y a tous sur les spoiler et les menu déroulant
http://bormat2.free.fr/tutoriel-menu-déroulant.html
Ajouter un commentaire
Réponse
+1
moins plus
pour ajouter se code dans la pages html fait comme ceci:

=========================================================

<script type="text/javascript">
function montrer_spoiler(value) {
	var actual=document.getElementById(value).style.visibility;
	if (actual=='visible') {
		document.getElementById(value).style.visibility='hidden';
	} else {
		document.getElementById(value).style.visibility='visible';
	}
}
</script>
<div class="container"><table class="spoiler" onclick="javascript:montrer_spoiler('spoiler2')" style="cursor: pointer;"><tbody><tr class="none"><td><b class="s1Topic">Spoiler :</b><br><br><div class="Topic masque" id="spoiler2">{TEXT}
</div></td></tr></tbody></table></div>



=========================================================

puis il faut modifier {TEXT} par le texte que tu veut
Ajouter un commentaire
Réponse
+1
moins plus
C'est parce que l'état initial n'est pas contenu dans le javascript mais dans la classe CSS. Le javascript lui change l'état de la propriété CSS "visiblility" en fonction de l'état précédent. Personnellement j'utiliserais plutôt la propriété display en passant de block à none. Visibility de visible à hidden ne fait que maquer le contenu mais sa place dans l'affichage lui reste réserver, alors qu'avec display, quand tu passes la valeur à none, c'est comme si le truc n'était plus là du tout.
Dans l'exemple précédent que j'ai regardé rapidemment, l'état initial est donc défini dans la classe CSS "container". Si tu ne la définis pas, par défaut, la proprité visibility est à visible.

Voilou
gloutonConfiguration: Windows XP Firefox 2.0.0.6
Ajouter un commentaire
Réponse
+1
moins plus
j'ai réglé le problème de lpareo

voici le bon code :

<script type="text/javascript">
function montrer_spoiler(value) {
var actual=document.getElementById(value).style.visibility;
if (actual=='visible') {
document.getElementById(value).style.visibility='hidden';
} else {
document.getElementById(value).style.visibility='visible';
}
}
</script>
<div class="container"><table class="spoiler" onclick="javascript:montrer_spoiler('spoiler2')"
style="cursor: pointer;"><tbody><tr class="none"><td><b class="s1Topic"> On clique sur ce texte pour afficher le reste !!! </b><br><br>
<div class="Topic_masque" id="spoiler2">

Texte

</div></td></tr></tbody></table></div>

et dans ton fichier css, ou directement dans le fichier html ou php, en rajoutant une balise css tu met

.topic_masque

{
visibility: hidden;
}

voila, et c'est pas de moi, j'ai pris le code de takerman qui date du 21 aout 2007, et j'ai passé 5 minutes a tester différents noms de class pour le css.

il affichera le nom en gras et centré, il y aura une plage invisible aussi longue que ton texte caché, et quand tu cliqueras, ca l'affichera en centré

ce code est pratique pour les cas ou il n'y a qu'une ou deux lignes a afficher
mais pour un cas ou il y a une page entière, mieux vaux prendre celui de takerman du 9 décembre 2007.
meme si il y a un léger bug (il n'affiche en effet rien quand tu cliques sur le bouton, je vais essayer de régler ca, meme si je ne m'y connais pas en codage java
voila
Ajouter un commentaire
Réponse
+0
moins plus
ok mais comment on en fais un ??!!??
Ajouter un commentaire
Réponse
+0
moins plus
... regarde le code du forum :

<div class="container"><table class="spoiler" onclick="javascript:montrer_spoiler('spoiler2')" style="cursor: pointer;"><tbody><tr class="none"><td><b class="s1Topic">Spoiler :</b><br><br><div class="Topic masque" id="spoiler2"><p>escargot</p></div></td></tr></tbody></table></div>


La fonction Javascript associée n'est pas bien méchante :
http://forum.hardware.fr/include/forum2.js

function montrer_spoiler(value) {
	var actual=document.getElementById(value).style.visibility;
	if (actual=='visible') {
		document.getElementById(value).style.visibility='hidden';
	} else {
		document.getElementById(value).style.visibility='visible';
	}
}




Ajouter un commentaire
Réponse
+0
moins plus
ok merci :D
Ajouter un commentaire
Réponse
+0
moins plus
Salut,
ce code marche sur mon forum seulement, il est d'abord visible puis il faut cliquer dessus pour le rendre invisible.
J'aime savoir comment faire pour qu'il soit invisible la première fois qu'on le voit ?
j'ai remplacé "actual visible" par hidden" mais ça ne marche plus comme ça ...
merci
Ajouter un commentaire
Réponse
+0
moins plus
up please :(Configuration: Windows XP Internet Explorer 7.0
Ajouter un commentaire
Réponse
+0
moins plus
bonjour a tous, je vois que vous avez de bonne connaissance
alors voila, tout ces spoiler son bien jolie mais ce que je recherche n'y ai pas exactement ...
je cherche un spoilé comme présent sur ce forum :
http://xooit.xooit.com/...

un spoiler qui se déplie progressivement, et non un texte qui apparait d'un coups, et qui ne fait pas de gros troues dans l'affichage de la page..
en quelque sorte se serait le top du spoiler non ? :)

j'ai esseyé de reprendre le code, en très gros le code ressemble a ça non ?

<div><a href="javascript:void(0);"
onclick="hideBBCodeShowHide(this)">Spoiler  : </a></div>
<div style="display: none;">
TEXTE
<span class="postbody"></span></div>
</div>

serait il possible de l'appliquer a une page web ? parce que tel quel le texte ne s'affiche pô !
merci ;)
Ajouter un commentaire
Réponse
+0
moins plus
peut-être n'as-tu pas inclu dans ta page la fonction javascript hideBBCodeShowHide()...

j'ai récupéré dans le code source de ta page d'exemple le fichier .js contenant la fonction en question (http://img3.xooimage.com/files/c/1/5/common-424e3c.js?2_20080531)...mais c'est un vrai capharnaum pour y comprendre quelque chose. Au pire enregistres le .js en entier et utilises-le tel quel.

J'ai reussi en tatonnant a  virer quelques trucs n'ayant pas de rapport avec la fonction de "spoilerization", mais une grande partie reste opaque pour moi : la fonction hideBBCodeShowHide() fait appel à  2 autres fonctions Effect.SlideDown et Effect.SlideUp, mais après je m'y perds. Voilà , en espérant avoir pu t'aider un peu.
hounaa - 29 juil. 2008 à 21:55
Hey =)

Je voulais signaler que le code de takerman marche très bien =)
et je le remercie pour ce code =D
Ajouter un commentaire
Réponse
+0
moins plus
lu

<div class="container"><table class="spoiler" onclick="javascript:montrer_spoiler('spoiler2')" style="cursor: pointer;"><tbody><tr class="none"><td><b class="s1Topic">Spoiler :</b><br><br><div class="Topic masque" id="spoiler2"><p>escargot</p></div></td></tr></tbody></table></div>
*xan* - 12 avril 2009 à 15:27
Le code de takerman fonctionne effectivement très bien.

Merci beaucoup pour le coup de pouce.
Ajouter un commentaire
Réponse
+0
moins plus
http://sd-1.archive-host.com/membres/up/150114153040225939/66.HTM
la dernière réponse date de 2008 donc pas encore trop tard
avec le java script et le html ça ne fait que 5,74 ko à la place de 14 ou +
Ajouter un commentaire
Réponse
+0
moins plus
<div style="margin:20px; margin-top:5px"><div class="quotetitle"><b>Spoiler:</b> <input type="button" value="Afficher" style="width:45px;font-size:10px;margin:0px;padding:0px;" onclick="if (this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display != '') { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = ''; this.innerText = ''; this.value = 'Cacher'; } else { this.parentNode.parentNode.getElementsByTagName('div')[1].getElementsByTagName('div')[0].style.display = 'none'; this.innerText = ''; this.value = 'Afficher'; }" /></div><div class="quotecontent"><div style="display: none;">{moi sa marche pas aussi faut m'expliquer avec des mots clair svp}</div></div></div>
Anonyle_remerciant - 19 avril 2011 à 13:03
Sa c parfait !!!
Ajouter un commentaire
Réponse
+0
moins plus
spoiler n'est pas activer sur ccm essayé sur d'autre site ça marche
Ajouter un commentaire
Réponse
+0
moins plus
Bonjour je souhaiterai savoir si possible comment adapter ce script pour l'exécution de plusieurs spoilers dans la même page.

Merci.
Ajouter un commentaire
Réponse
+0
moins plus
Tu mets le messages que tu veux citer, et tu clique en haut à droite normalement sur "citer", c'est tout! ^^
Ajouter un commentaire
Ce document intitulé « [Spoiler] HTML » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
5 extensions si vous voulez revenir à l'ancien Facebook
[Spoiler] HTML - page 2