1. 問題の背景
AngularJS でタイマーを設定した後、ボタンをもう一度クリックしてタイマーをトリガーすると、次のメッセージが表示されます: 前のタイマーは停止しておらず、次のタイマーが再び開始されました。複数のタイマーが同時に表示されます。
2. 問題のソースコード
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>AngularJS之定时器无法停止</title> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> <script> var app = angular.module("btnApp",[]); app.controller("btnCon",function($scope,$interval){ $scope.count = 0; $scope.getDayTime = function(){ var date = new Date(); var year = date.getFullYear(); var month = date.getMonth()+1; var day = date.getDate(); var hour = date.getHours(); var minute = date.getMinutes(); var second = date.getSeconds(); var thisTime = year+"-"+(month<10?"0"+month:month)+"-"+(day<10?"0"+day:day)+" "+(hour<10?"0"+hour:hour)+":"+(minute<10?"0"+minute:minute)+":"+(second<10?"0"+second:second); return thisTime; }; $scope.dayTime = $scope.getDayTime(); $scope.queryData = function(){ var timer = $interval(function(){ $scope.count++; console.log($scope.count); },4000); $scope.$on("destroy",function(){ $interval.cancel($scope.timer); }); }; }); </script> </head> <body ng-app="btnApp"> <p ng-controller="btnCon"> <button ng-click="queryData();">查询</button> <p> <label>{{count}}</label> </p> </p> </body> </html>
3. 問題の結果
4. ソースコードを解決します
5. 解決策
上記は停止できない AngularJS タイマーの内容です。その他の関連コンテンツについては、PHP 中国語 Web サイト (m.sbmmt.com) に注目してください。