计时器创建:
/*
* Copyright (c) 2024 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
// 回调声明
type TimeChangeCallback = (hour: number, minute: number, second: number,) => void;
// 时钟刷新间隔
const REFRESH_INTERVAL = 1000;
export class TimeChangeListener {
private onTimeChange: TimeChangeCallback;
private intervalId: number = 0;
constructor(
onTimeChange: TimeChangeCallback
) {
// Store the callbacks
this.onTimeChange = onTimeChange;
// Start the time checking loop
this.intervalId = setInterval(() => this.checkTime(), REFRESH_INTERVAL); // Check every second
}
private checkTime(): void {
const now = new Date();
const currentHour = now.getHours();
const currentMinute = now.getMinutes();
const currentSecond = now.getSeconds();
// Check for second change
if (this.onTimeChange) {
this.onTimeChange(currentHour, currentMinute, currentSecond);
}
}
public clearInterval():void {
clearInterval(this.intervalId);
}
}
计时器应用:
this.intervalId = setInterval(()=>this.XXX(),REFLESH_INTERVAL)