Questa è la risposta più semplice che potevo venire con utilizzando $interval:
Example
Il JS
function TimeCtrl($interval) {
var timeController = this;
timeController.clock = { time: "", interval: 1000 };
$interval(function() {
timeController.clock.time = Date.now();},
timeController.clock.interval);
}
Il codice HTML
<div ng-controller='TimeCtrl as timeCtrl'>
<p>{{ timeCtrl.clock.time | date:'medium'}}</p>
</div>
Ecco un'implementazione timer utilizzando la stessa funzione di registrazione $ intervallo per registrare un nuovo intervallo su start e annullare l'intervallo su stop.
ATTENZIONE!Non è possibile associare al parametro $ intervallo di ritardo
Example
Il JS
function TimeCtrl($interval) {
var timeController = this;
timeController.clock = { time: "", interval: 1000 };
timeController.timer = { time: (new Date()).setHours(0,0,0,0), startTime: "", interval: 10};
timeController.timerProcess;
timeController.timerStart = function() {
// Register the interval and hold on to the interval promise
timeController.timerProcess = RegisterInterval(TimerTick, timeController.timer.interval);
// Reset the time to 0
timeController.timerReset();
}
timeController.timerReset = function() {
timeController.timer.startTime = Date.now();
timeController.timer.time = (new Date()).setHours(0,0,0,0);
}
timeController.timerStop = function() {
// If there is an interval process then stop it
if(timeController.timerProcess){
$interval.cancel(timeController.timerProcess);
}
}
function ClockTick() {
timeController.clock.time = Date.now();
}
function TimerTick(){
// Increment the time by the time difference now and the timer start time
timeController.timer.time += Date.now() - timeController.timer.startTime;
// Reset the start time
timeController.timer.startTime = Date.now();
}
function RegisterInterval(regFunction, regInterval){
return $interval(regFunction, regInterval);
}
RegisterInterval(ClockTick, timeController.clock.interval);
}
Il codice HTML
<div ng-controller='TimeCtrl as timeCtrl'>
<p>Date: {{ timeCtrl.clock.time | date:'medium'}}</p>
<p>Timer: {{ timeCtrl.timer.time | date:'mm:ss:sss'}}</p>
<button type="button" ng-click="timeCtrl.timerStart()">Start</button>
<button type="button" ng-click="timeCtrl.timerReset()">Reset</button>
<button type="button" ng-click="timeCtrl.timerStop()">Stop</button>
</div>
fonte
2016-02-10 18:36:08
Ciò potrebbe essere realizzato in modo più elegante utilizzando $ dell'intervallo. –
Ho alcune domande: perché non iniziare usando solo tick(); e perché usare scope e non qualcosa lick var time = this ;? – olahell
Dovresti anche usare una direttiva per farlo ed essere in grado di fare qualcosa del tipo: ' corrente-tempo>' –
OpensaurusRex