11521 sujets

JavaScript, DOM et API Web HTML5

bonjour

dans mon fichier html jai la fonction onclik que je dois transformer par addEventListener à mettre dans mon fichier js..

voici mes codes :

<!DOCTYPE html PUBLIC>
<html>
<head>
<meta charset="utf-8" />
<title>exercice11</title>
      
         <script src="script.js"></script>
			<link rel="stylesheet" type="text/css" href="docstyle.css" /> 
	
</head>
<body>

<form name="forsec">
<input type="text" size="3" name="secb" value="00">
<input type="text" size="3" name="seca" value="00">
<input type="text" size="3" name="secc"value ="00">

<input type="button" value="Chrono" onclick="chrono()">

<input type="button" value="Tempo" onclick="clearTimeout(compte)">
<input type="button" value="RaZ" onclick="rasee()">

</form>

</body>
</html>


var centi=0 
var secon=0 
var minu=0 

function chrono(){
centi++; //incrémentation des dixièmes de 1
if (centi>9){centi=0;secon++} //si les dixièmes > 9,
if (secon>59){secon=0;minu++} //si les secondes > 59,

document.forsec.secc.value=" "+centi 
document.forsec.seca.value=" "+secon 
document.forsec.secb.value=" "+minu
compte=setTimeout('chrono()',100) 
//tous les 10° de secondes
}

function rasee(){ 
clearTimeout(compte) 
centi=0;
secon=0;
minu=0;
document.forsec.secc.value=" "+centi
document.forsec.seca.value=" "+secon
document.forsec.secb.value=" "+minu
}


je n'arrive pas a transformer avec la fonction addEventListener. est ce que je dois mettre document.getElementById ? comment le remplacer par document.forsec.secc.value=" "+centi

merci
Modifié par moon28 (24 Aug 2017 - 23:16)
Bonjour,

Il faut mettre un id unique sur chaque input, donc par exemple:

<input type="button" value="Chrono" id="premierBoutton">



var premierBoutton = document.getElementById('premierBoutton').addEventListener('click', chrono);

Modifié par allan00958 (25 Aug 2017 - 09:43)
merci pour ta réponse , j'ai essayer ca ne marche pas ..

<form name="forsec">
<input type="text" size="3" name="secb" value="00">
<input type="text" size="3" name="seca" value="00">
<input type="text" size="3" name="secc"value ="00">

		<input type="button" id="demarre" value="Start" />
		<input type="button" id="pause" value="Pause" />
		<input type="button" id="efface" value="clear" />

</form>

var centi=0 // initialise les dixtièmes
var secon=0 //initialise les secondes
var minu=0 //initialise les minutes


var demarre = document.getElementById('demarre').value;
var pause = document.getElementById('pause').value;
var efface = document.getElementById('efface').value;


function chrono(){
centi++; //incrémentation des dixièmes de 1
if (centi>9){centi=0;secon++} //si les dixièmes > 9,
//on les réinitialise à 0 et on incrémente les secondes de 1
if (secon>59){secon=0;minu++} //si les secondes > 59,
//on les réinitialise à 0 et on incrémente les minutes de 1
document.forsec.secc.value=" "+centi //on affiche les dixièmes
document.forsec.seca.value=" "+secon //on affiche les secondes
document.forsec.secb.value=" "+minu //on affiche les minutes
compte=setTimeout('chrono()',100) //la fonction est relancée
//tous les 10° de secondes
document.getElementById("demarre").action=true;
}

function rasee(){ //fonction qui remet les compteurs à 0
document.getElementById("demarre").action=false;
centi=0;
secon=0;
minu=0;
document.forsec.secc.value=" "+centi
document.forsec.seca.value=" "+secon
document.forsec.secb.value=" "+minu
}
function stop(){
			clearTimeout(compte);//arrête la fonction chrono()
			document.getElementById("demarre").action=false;
		}
		
 window.addEventListener("load",function(){
document.getElementById('demarrer').addEventListener('click', chrono);
document.getElementById('pause').addEventListener('click', stop);
document.getElementById('efface').addEventListener('click', rasee);
 });
  


en fait dans le document js je sais pas comment régler, si je dois supprimer quelque chose ou modifier,,?

Merci
Ah la il y a une erreur ds la console:
SyntaxError: missing } after function body[En savoir plus] script.js:48


[b]</pre><menu type="context" id="actions">[/b]<menuitem id="goToLine" label="Aller à la ligne…" accesskey="l"></menuitem><menuitem id="wrapLongLines" label="Retour à la ligne automatique" type="checkbox" checked="true"></menuitem><menuitem id="highlightSyntax" label="Coloration syntaxique" type="checkbox" checked="true"></menuitem></menu></body></html>


ce qu'il y a en gras qui est surligné dans la console mais je comprends pas
Modifié par moon28 (25 Aug 2017 - 17:28)
allan00958 a écrit :
Il ne faut retirer window.addEventListener("load",function(){}


merci ca n'a pas marchait non plus Smiley decu
allan00958 a écrit :
J'ai fixé les erreurs de synthaxe vite fait mais le code ne fonctionne pas. Personnellement, je pense qu'il est à refaire complètement....

https://jsfiddle.net/3fp6t404/1/

C'est pas sûr que je puisse aider ce week-end. On verra......


merci Allan oui sinon je remet mon script d'origine

https://jsfiddle.net/3pLh4r8y/

ca fonctionne dans jsfiddle!! mais pas dans firefox ni chrome..... je comprends pas
Modifié par moon28 (26 Aug 2017 - 22:17)