Voilà j'ai voulu faire un toggle pour mon site et j'ai trouvé un script sur google et j'ai voulu le modifier mais il marche plus:
Voici le script:
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.height = this.int + 'px';
this.int++;
if(this.int == this.height) { this.StopTimer(); }
},
Hide: function(){
this.mode = 'hide';
this.element.style.height = this.int + 'px';
if(this.int == 0)
{
this.StopTimer();
this.mode = '';
}
this.int--;
},
StartTimer: function(){
if(this.timeval == '')
{
if ((this.start == 1 && this.int == this.height) || this.mode == "hide")
{
this.timeval = setInterval('Toggle.Show()', 10);
}
else
{
this.timeval = setInterval('Toggle.Hide()', 10);
}
}
else
{
this.StopTimer();
}
},
StopTimer: function(){
if(this.timeval != '')
{
clearInterval(this.timeval);
this.timeval = '';
}
}
};
Je l'utilise ainsi:
Code : Tout sélectionner
<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>Sous IE le script déplie bien le div petit à petit mais s'arrête jamais.
Sous Firefox, Safari, Opera, Google Chrome le script ne fait rien du tout il affiche rien.
Quand je fais un alert(this.height); dans la fonction Init() juste avant l'appel de la fonction this.StartTimer(); il me renvoit 0.
Je vous met le script original qui lui fonctionnait:
<script type="text/javascript">
var hauteur, elements, ousuisje;
var premier=0;
var int=0;
function toggleMe(el) {
elements=document.getElementById(el);
if (premier == 0) {
hauteur=elements.clientHeight;
premier++;
}
start_Timer();
}
function bas() {
elements.style.visibility = "inherit";
elements.style.height = int+"px";
int++;
if (int == hauteur)
stop_Timer();
}
function haut() {
ousuisje="haut";
elements.style.height=int+"px";
if (int == 0) {
stop_Timer();
ousuisje="";
}
int--;
}
var timeval=""; //ploooop
function start_Timer(){
if(timeval==""){
if ((premier == 1 && int == hauteur) || ousuisje=="haut") {
timeval=window.setInterval("haut()", 20);
} else {
timeval=window.setInterval("bas()", 20);
}
} else {
stop_Timer()
}
}
function stop_Timer(){
if(timeval!=""){
window.clearInterval(timeval)
timeval=""
}
}
</script>
<a href="#" onclick="toggleMe('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.
</div>
Merci d'avance...