par
djtec » 26 déc. 2008, 13:49
Bonjour Elie,
Je ne veux pas me mettre à Prototype ni à JQuery ni une autre librairie car je voudrais développer mes propre scripts sans librairie et puis cela me permet d'apprendre aussi le javascript.
Voici le code qui fonctionne très bien:
<script type="text/javascript">
var Toggle = {
height: '',
element: '',
start: 0,
int: 0,
mode: '',
timeval: '',
Init: function(htmlelement){
this.element = document.getElementById(htmlelement);
if(this.start == 0)
{
this.height = this.element.clientHeight;
this.start++;
}
this.StartTimer();
},
Show: function(){
this.element.style.visibility = 'inherit';
this.element.style.maxHeight = this.int + 'px';
this.int++;
if(this.int == this.height) { this.StopTimer(); }
},
Hide: function(){
this.mode = 'hide';
this.element.style.maxHeight = this.int + 'px';
if(this.int == 0)
{
this.StopTimer();
this.mode = '';
this.element.style.visibility = 'hidden';
}
this.int--;
},
StartTimer: function(){
if(this.timeval == '')
{
if ((this.start == 1 && this.int == this.height) || this.mode == "hide")
{
this.timeval = setInterval("Toggle.Hide()", 10);
}
else
{
this.timeval = setInterval("Toggle.Show()", 10);
}
}
else
{
this.StopTimer();
}
},
StopTimer: function(){
if(this.timeval != '')
{
clearInterval(this.timeval);
this.timeval = '';
}
}
};
</script>
Mais maintenant j'ai un autre problème, car se code fonctionne parfaitement quand je fais qu'un seul toggle dans une page.
Mais si je veux faire deux toggle cela ne marche plus très bien.
Voici le code complet avec deux toogle:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Effet Toggle</title>
<script type="text/javascript">
var Toggle = {
height: '',
element: '',
start: 0,
int: 0,
mode: '',
timeval: '',
Init: function(htmlelement){
this.element = document.getElementById(htmlelement);
if(this.start == 0)
{
this.height = this.element.clientHeight;
this.start++;
}
this.StartTimer();
},
Show: function(){
this.element.style.visibility = 'inherit';
this.element.style.maxHeight = this.int + 'px';
this.int++;
if(this.int == this.height) { this.StopTimer(); }
},
Hide: function(){
this.mode = 'hide';
this.element.style.maxHeight = this.int + 'px';
if(this.int == 0)
{
this.StopTimer();
this.mode = '';
this.element.style.visibility = 'hidden';
}
this.int--;
},
StartTimer: function(){
if(this.timeval == '')
{
if ((this.start == 1 && this.int == this.height) || this.mode == "hide")
{
this.timeval = setInterval("Toggle.Hide()", 10);
}
else
{
this.timeval = setInterval("Toggle.Show()", 10);
}
}
else
{
this.StopTimer();
}
},
StopTimer: function(){
if(this.timeval != '')
{
clearInterval(this.timeval);
this.timeval = '';
}
}
};
</script>
<style>
body{ background-color:#999; }
#test{
visibility:hidden;
background-color:#666;
color:#fff;
font-size:10px;
font-family:Arial, Helvetica, sans-serif;
overflow:hidden;
padding:3px;
}
#test2{
visibility:hidden;
background-color:#666;
color:#fff;
font-size:10px;
font-family:Arial, Helvetica, sans-serif;
overflow:hidden;
padding:3px;
}
</style>
</head>
<body>
<a href="#" onclick="Toggle.Init('test');">Toggle Moi !</a>
<div id="test">Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales
hendrerit.Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales
hendrerit.Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales hendrerit.
</div>
<a href="#" onclick="Toggle.Init('test2');">Toggle Moi !</a>
<div id="test2">Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales
hendrerit.Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales
hendrerit.Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales hendrerit.
</div>
</body>
</html>
Le problème c'est que déjà les deux liens sont espacés comme si les div étaient déplié, ensuite quand je clique sur le premier le deuxième vient se coller direct au premier puis ils descendent tout les deux, quand je clique sur le deuxième rien ne se passe.
Donc comme faire???
Merci d'avance...
Bonjour Elie,
Je ne veux pas me mettre à Prototype ni à JQuery ni une autre librairie car je voudrais développer mes propre scripts sans librairie et puis cela me permet d'apprendre aussi le javascript.
Voici le code qui fonctionne très bien:
[php]<script type="text/javascript">
var Toggle = {
height: '',
element: '',
start: 0,
int: 0,
mode: '',
timeval: '',
Init: function(htmlelement){
this.element = document.getElementById(htmlelement);
if(this.start == 0)
{
this.height = this.element.clientHeight;
this.start++;
}
this.StartTimer();
},
Show: function(){
this.element.style.visibility = 'inherit';
this.element.style.maxHeight = this.int + 'px';
this.int++;
if(this.int == this.height) { this.StopTimer(); }
},
Hide: function(){
this.mode = 'hide';
this.element.style.maxHeight = this.int + 'px';
if(this.int == 0)
{
this.StopTimer();
this.mode = '';
this.element.style.visibility = 'hidden';
}
this.int--;
},
StartTimer: function(){
if(this.timeval == '')
{
if ((this.start == 1 && this.int == this.height) || this.mode == "hide")
{
this.timeval = setInterval("Toggle.Hide()", 10);
}
else
{
this.timeval = setInterval("Toggle.Show()", 10);
}
}
else
{
this.StopTimer();
}
},
StopTimer: function(){
if(this.timeval != '')
{
clearInterval(this.timeval);
this.timeval = '';
}
}
};
</script>[/php]
Mais maintenant j'ai un autre problème, car se code fonctionne parfaitement quand je fais qu'un seul toggle dans une page.
Mais si je veux faire deux toggle cela ne marche plus très bien.
Voici le code complet avec deux toogle:
[php]<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Effet Toggle</title>
<script type="text/javascript">
var Toggle = {
height: '',
element: '',
start: 0,
int: 0,
mode: '',
timeval: '',
Init: function(htmlelement){
this.element = document.getElementById(htmlelement);
if(this.start == 0)
{
this.height = this.element.clientHeight;
this.start++;
}
this.StartTimer();
},
Show: function(){
this.element.style.visibility = 'inherit';
this.element.style.maxHeight = this.int + 'px';
this.int++;
if(this.int == this.height) { this.StopTimer(); }
},
Hide: function(){
this.mode = 'hide';
this.element.style.maxHeight = this.int + 'px';
if(this.int == 0)
{
this.StopTimer();
this.mode = '';
this.element.style.visibility = 'hidden';
}
this.int--;
},
StartTimer: function(){
if(this.timeval == '')
{
if ((this.start == 1 && this.int == this.height) || this.mode == "hide")
{
this.timeval = setInterval("Toggle.Hide()", 10);
}
else
{
this.timeval = setInterval("Toggle.Show()", 10);
}
}
else
{
this.StopTimer();
}
},
StopTimer: function(){
if(this.timeval != '')
{
clearInterval(this.timeval);
this.timeval = '';
}
}
};
</script>
<style>
body{ background-color:#999; }
#test{
visibility:hidden;
background-color:#666;
color:#fff;
font-size:10px;
font-family:Arial, Helvetica, sans-serif;
overflow:hidden;
padding:3px;
}
#test2{
visibility:hidden;
background-color:#666;
color:#fff;
font-size:10px;
font-family:Arial, Helvetica, sans-serif;
overflow:hidden;
padding:3px;
}
</style>
</head>
<body>
<a href="#" onclick="Toggle.Init('test');">Toggle Moi !</a>
<div id="test">Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales
hendrerit.Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales
hendrerit.Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales hendrerit.
</div>
<a href="#" onclick="Toggle.Init('test2');">Toggle Moi !</a>
<div id="test2">Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales
hendrerit.Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales
hendrerit.Lorem ipsum dolor sit amet, consectetuer 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. Maecenas adipiscing ante non diam sodales hendrerit.
</div>
</body>
</html>[/php]
Le problème c'est que déjà les deux liens sont espacés comme si les div étaient déplié, ensuite quand je clique sur le premier le deuxième vient se coller direct au premier puis ils descendent tout les deux, quand je clique sur le deuxième rien ne se passe.
Donc comme faire???
Merci d'avance...