Précédent   Forum des professionnels en informatique > Webmasters - Développement Web > JavaScript > Bibliothèques & Frameworks > Mootools
Mootools Forum d'entraide sur le framework MooTools. Avant de poster : Tutoriels Mootools, FAQ MooTools, Toutes les FAQ JavaScript
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 11/05/2007, 15h29   #1
Membre régulier
 
Avatar de keub51
 
Inscription : janvier 2007
Messages : 349
Détails du profil
Informations forums :
Inscription : janvier 2007
Messages : 349
Points : 79
Points : 79
Par défaut Mootools Menu accordeon

Bonjour,

jai un menu mootools en accordeon et j'aimerai qu'au demarrage de la page tout les rubriques soient fermées. Voici mon code :

Code :
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
<!-- inclusion du fichier Mootools-->
<script type="text/javascript" src="mootools.release.83.js"></script> 
 
<style type="text/css">
	  body 
	 {
		background : black;
		color : white;
	 }
 
	 h1 
	 {
	 	text-transform : uppercase;
	 	font-size : 24px;
	 }	 
 
	  #barre_navigation {
	  	width : 15%;
	    padding: 0 ;
	    margin : 0;
	    float : right ;
		border : 1px solid white;
	  }
 
	  #barre_navigation h4{
	  	padding: 4px 10px ;
		font-size: 12px;
		font-weight: normal;
		text-transform: uppercase;
		background: white;
		cursor: pointer;    
		margin : 0 0 1px 0 ;
	  }
 
	  #barre_navigation a{
	  	text-decoration : none;
		font-family : "Comic sans Ms","trebuchet MS",arial,default;
	  }
 
 
	  #barre_navigation ul{
	  	padding: 4px 2px 4px 10px;;
		font-size: 11px;
 
	  }
 
	  #barre_navigation ul li{
	  	list-style-type : none;
	  	padding : 2px 0 2px 0;
	  	margin : 0;
	  }
 
	  #barre_navigation ul li a {
	    text-decoration: none;
	    color: #FFF;
	  }
 
	  #barre_navigation ul li a:hover {
	    text-decoration: none;
	  }
 
</style>
 
<!-- ici notre barre de navigation en accordeon-->
<div id="barre_navigation">
 
	<h4 class="toggler"><a href="#">Nordtech</a></h4>
	<div class="accordeon">
		<ul>	
					<li><a href="#" title="Nordtech Activitées">Activitées</a></li>
					<li><a href="#" title="Nordtech Produits">Produits</a></li>
					<li><a href="#" title="Nordtech Adresse">Adresse</a></li>
					<li><a href="#" title="Nordtech Juridique">F. Juridique</a></li>
		</ul>
	</div>
 
 
	<h4 class="toggler"><a href="#">Fournisseurs</a></h4>
	<div class="accordeon">
		<ul>	
					<li><a href="#" title="Nordtech Selection">Sélection</a></li>
					<li><a href="#" title="Nordtech Marque">Marque</a></li>		
		</ul>
	</div>
 
 
	<h4 class="toggler"><a href="#">Clients</a></h4>
 
	<div class="accordeon">
		<ul>	
						<li><a href="#" title="Nordtech Qui">Qui?</a></li>
					<li><a href="#" title="Nordtech Contact">Contact</a></li>
					<li><a href="#" title="Nordtech Client">Formulaire Client</a></li>
					<li><a href="#" title="Nordtech Entreprise">Pack créateur d'entreprise</a></li>
					<li><a href="#" title="Nordtech Délai">Délai</a></li>			
		</ul>
	</div>	
	<h4 class="toggler"><a href="#">Ce site</a></h4>
	<div class="accordeon">
		<ul>	
	<li><a href="#" title="Nordtech Pourquoi">Pourquoi ?</a></li>
					<li><a href="#" title="Nordtech Newsletter">Newsletter</a></li>				
		</ul>
	</div>
 
 
	<h4 class="toggler"><a href="#">Opportunité</a></h4>
	<div class="accordeon">
		<ul>	
			<li><a href="#" title="Nordtech Partenariat">Partenariat</a></li>	
		</ul>
	</div>
 
 
	<h4 class="toggler"><a href="#">Webmaster</a></h4>
 
	<div class="accordeon">
		<ul>	
			<li><a href="#" title="Nordtech Partenariat">Partenariat</a></li>	
		</ul>
	</div>	
	<h4 class="toggler"><a href="#">Autres</a></h4>
 
	<div class="accordeon">
		<ul>	
					<li><a href="#" title="Nordtech Presse">La presse</a></li>
					<li><a href="#" title="Nordtech Liens constructeurs">Liens constructeurs</a></li>	
		</ul>
	</div>
</div>
 
<!-- ici notre conteu mis a jour en ajax-->
<div id="contenu">
 
<script type="text/javascript">
 
//pour commencer avec les elements fermés au départs
var stretchers = $$('div.accordeon');
stretchers.each(function(item){
	item.setStyles({'height': '0', 'overflow': 'hidden'});
});
 
 
//au chargement de la page
window.onload = function(){ 
 
	var togglers = $$('h4.toggler'); //on met dans la variable togglers tous les div H4 de la page appartenant a la classe toggler. C'est la syntaxe $$ de element de Mootools qui permet cela très facilement
 
	var bgFx = []; //variable pour la gestion des couleurs de fond
 
	togglers.each(function(toggler, i){
		toggler.defaultColor = toggler.getStyle('background-color');
 
		//fx creation
		bgFx[i] = new Fx.Color(toggler, 'background-color', {wait: false});
	});
 
	// creation de l'effet accordeon
	//syntaxe : new Fx.Accordion(quel_div_visible, quel_div_a_afficher, {options eventuelles});
	var myAccordion = new Fx.Accordion(togglers, stretchers, { opacity: false, start: false, transition: Fx.Transitions.quadOut,
 
		onActive: function(toggler, i){
			bgFx[i].toColor('#004A77'); //quand un element est actif
			toggler.getFirst().setStyle('color', '#fff');
		},
 
		onBackground: function(toggler, i){
			bgFx[i].clearTimer(); //quand un element n'est actif
			toggler.setStyle('background-color', toggler.defaultColor);
			toggler.getFirst().setStyle('color', '#222');
		}
	});
 
	//permet de reouvrir directement le bon element 
	//grace à l'url test.html#cat_a_ouvrir
	function checkHash(){
		var found = false;
		$$('h4.toggler a').each(function(link, i){
			if (window.location.hash.test(link.hash)){
				myAccordion.showThisHideOpen(i);
				found = true;
			}
		});
		return found;
	}
 
	if (!checkHash()) myAccordion.showThisHideOpen(0);
 
 
};
 
//pour commencer avec les elements fermés au départs
var stretchers = $$('div.accordeon');
stretchers.each(function(item){
	item.setStyles({'height': '0', 'overflow': 'hidden'});
});
 
</script>
normalment avec ce bout de code :

Code :
1
2
3
4
var stretchers = $$('div.accordeon');
stretchers.each(function(item){
	item.setStyles({'height': '0', 'overflow': 'hidden'});
});
ca devrait fermer toutes les rubriques au demarrage de la fenetre ... mais non ...

quelqu'un a une idée ?
keub51 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/05/2007, 18h00   #2
Membre régulier
 
Avatar de keub51
 
Inscription : janvier 2007
Messages : 349
Détails du profil
Informations forums :
Inscription : janvier 2007
Messages : 349
Points : 79
Points : 79
apparament le mootools nest pas votre ami ...
keub51 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/05/2007, 18h45   #3
Expert Confirmé Sénior
 
Avatar de Auteur
 
Inscription : avril 2004
Messages : 4 796
Détails du profil
Informations personnelles :
Localisation : France

Informations forums :
Inscription : avril 2004
Messages : 4 796
Points : 5 119
Points : 5 119
bonjour,

Visiblement il manque la définition de la classe "acordeon" dans ta feuile de style.

Un
Code css :
1
2
 
display: none;
dans cette CSS devrait suffire.
Auteur est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 23/05/2007, 16h56   #4
Membre actif
 
Avatar de lapanne
 
Inscription : juin 2006
Messages : 200
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 200
Points : 168
Points : 168
Envoyer un message via MSN à lapanne
yop,

dans ta déclaration de la classe Accordion, rejoute juste l'option show=-1. Ce qui devrait donner une truc comme ça :

Code :
 accordion = new Accordion('h3.Niveau1', 'div.Niveau1', {opacity: false,show:-1}, $('Menu_Gauche'));
__________________
<SplyRock95> c'est quoi ton style?
<Bat> #bat{height:180cm;weight:160lbs; eye-color:#0000FF; hair-color: #FFFF00;}
Copyright @ bashfr.org
lapanne est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 19h19.


 
 
 
 
Partenaires

Hébergement Web