Précédent   Forum du club des développeurs et IT Pro > Webmasters - Développement Web > Contribuez
Contribuez Proposez vos articles, cours, tutoriels, questions/réponses pour les FAQ, sources et autres ressources pour la rubrique Web ainsi que ses sous-rubriques.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse
 
Outils de la discussion
Publicité
'
Vieux 12/01/2013, 01h08   #1
danielhagnoul
Rédacteur
 
Avatar de danielhagnoul
 
Homme Daniel Hagnoul
Étudiant perpétuel
Inscription : février 2009
Messages : 3 849
Détails du profil
Informations personnelles :
Nom : Homme Daniel Hagnoul
Âge : 62
Localisation : Belgique

Informations professionnelles :
Activité : Étudiant perpétuel
Secteur : Enseignement

Informations forums :
Inscription : février 2009
Messages : 3 849
Points : 14 350
Points : 14 350
Par défaut Exécute une action à la minute ou à la seconde prévue

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
/*
 * Exécute une action à la minute prévue, toutes
 * les 5 minutes en commençant à hh:03.
 * 
 * Le programme exécute la fonction de rappel lorsque l'une
 * des valeurs de l'array tab est égale au nombre de minutes
 * dans l'heure puis s'interrompt pendant 4 minutes avant de
 * reprendre son travail chaque seconde.
 * 
 * Si boolMinute est false, le programme exécute une action
 * toutes les 5 secondes et se repose 2,5 secondes.
 */
function execute( callback, boolMinute ){
	var bool = boolMinute || true,
		appel = callback || function(){},
		tab = [ 3, 8, 13, 18, 23, 28, 33, 38, 43, 48, 53, 58 ],
		objInterval = setInterval( function(){
			tab.forEach( function( value ){
				if ( bool && value == new Date().getMinutes() ){
					appel( value );
					clearInterval( objInterval );
					setTimeout( function(){
						execute( appel, bool );
					}, 240000 ); // repos pendant 60000 * 4 minutes
					return;
				} else if ( value == new Date().getSeconds() ){
					appel( value );
					clearInterval( objInterval );
					setTimeout( function(){
						execute( appel, bool );
					}, 2500 ); // repos pendant 2,5s
					return;
				}
			});
		}, 1000 );
}
 
function action( valeur ){
	console.log( valeur );
}
 
execute( action ); // ou execute( action, false );
__________________

FAQ jQuery

Mon cahier d’exercices sur jQuery & Co

plugin dialogModal

Si un message vous a aidé ou vous semble pertinent, votez pour lui !
danielhagnoul est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/01/2013, 08h58   #2
danielhagnoul
Rédacteur
 
Avatar de danielhagnoul
 
Homme Daniel Hagnoul
Étudiant perpétuel
Inscription : février 2009
Messages : 3 849
Détails du profil
Informations personnelles :
Nom : Homme Daniel Hagnoul
Âge : 62
Localisation : Belgique

Informations professionnelles :
Activité : Étudiant perpétuel
Secteur : Enseignement

Informations forums :
Inscription : février 2009
Messages : 3 849
Points : 14 350
Points : 14 350
Par défaut Version 1.1.0 !

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
/*
 * Exécute une action selon l'horaire prévu dans l'array
 * horaireArray, en secondes.
 * 
 * Le programme exécute la fonction de rappel lorsque l'une
 * des valeurs de horaireArray est égale au nombre de secondes
 * de l'instant T.
 * 
 * L'array horaireArray doit contenir exclusivement des 
 * nombres entiers.
 */
function execSecondes( horaireArray, callback ){
	var appel = callback || function(){},
		tab = horaireArray || [ 15, 30 ],
		last = -1;
 
	return setInterval( function(){
		tab.forEach( function( value ){
			if ( value != last && value == new Date().getSeconds() ){
				last = value;
				appel( value );
				return;
			}
		});
	}, 500 );
}
 
/*
 * Exécute une action selon l'horaire prévu dans l'array
 * horaireArray, en minutes.
 * 
 * Le programme exécute la fonction de rappel lorsque l'une
 * des valeurs de horaireArray est égale au nombre de minutes
 * de l'instant T.
 * 
 * L'array horaireArray doit contenir exclusivement des 
 * nombres entiers.
 */
function execMinutes( horaireArray, callback ){
	var appel = callback || function(){},
		tab = horaireArray || [ 15, 30 ],
		last = -1;
 
	return setInterval( function(){
		tab.forEach( function( value ){
			if ( value != last && value == new Date().getMinutes() ){
				last = value;
				appel( value );
				return;
			}
		});
	}, 1000 );
}
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
/*
 * Exemple 1.
 * 
 * Exécute la fonction action selon l'horaire prévu en secondes.
 */
function actionSecondes( valeur ){
	console.log( "secondes = ", valeur );
}
 
var ObjIntervalSecondes = execSecondes( [ 3, 8, 13, 18, 23, 28, 33, 38, 43, 48, 53, 58 ], actionSecondes );
 
setTimeout( function(){
	clearInterval( ObjIntervalSecondes );
}, 240000 ); // 60000 * 4 = 240000; 4 minutes !
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
/*
 * Exemple 2.
 * 
 * Exécute la fonction action selon l'horaire prévu en minutes.
 */
function actionMinutes( valeur ){
	console.log( "minutes = ", valeur );
}
 
var ObjIntervalMinutes = execMinutes( [ 3, 7, 15, 22, 28, 31, 32, 45, 53, 59 ], actionMinutes );
 
setTimeout( function(){
	clearInterval( ObjIntervalMinutes );
}, 7200000 ); // 60000 * 60 * 2 = 7200000; 2 h !
__________________

FAQ jQuery

Mon cahier d’exercices sur jQuery & Co

plugin dialogModal

Si un message vous a aidé ou vous semble pertinent, votez pour lui !
danielhagnoul est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse
Outils de la discussion

Navigation rapide


Fuseau horaire GMT +2. Il est actuellement 21h42.


 
 
 
 
Partenaires

Hébergement Web