angularjs使用directive實現倒計時按鈕

前不久在作一個彩票的項目時,有一個手動開獎的需求。因此有了這個倒計時按鈕。下面分享下具體的代碼:函數

效果:spa

 

代碼:rest

App.directive('timerBtn', function() { // 倒計時按鈕
    return {
        restrict: 'A',
        replace: true,
        scope: {
            startTime: '=startTime',
            getData: '&getData'
        },
        template: '<button class="btn btn-danger" style="border-radius: 30px;padding: 3px 16px;" ng-disabled="startTime> 0" ng-bind="startTime > 0 ? showTime + \' 後開獎\' : \'手動開獎\'" ng-click="getData()"></button>',
        controller: function($scope, $interval) {

            var formatTime = function(second) {
                return [parseInt(second / 60 / 60), parseInt(second / 60 % 60), second % 60].join(":")
                    .replace(/\b(\d)\b/g, "0$1");
            }
            
            var timer = $interval(function() {
                $scope.startTime -= 1;
                $scope.showTime = formatTime($scope.startTime);
                if($scope.startTime < 1) {
                    $interval.cancel(timer);
                };
            }, 1000);

        }
    };
});

這個組件接受兩個參數:code

startTime:用於接收倒計時開始時間的時間戳
getData:用於接收倒計時結束以後觸發的函數

用法:
<div timer-btn start-time="time" get-data="getData()"></div>
相關文章
相關標籤/搜索