現在の時刻を表示するメッセージ ボックスを設定しました。タイマー間隔は 1000 に設定され、「タイマー」を開始および停止するための 2 つのボタンがあります。「停止」ボタンをクリックすると、Ext.TaskManager.stop メソッドが呼び出され、メッセージ ボックスのテキストが「一時停止」に更新されます。ただし、「停止」ボタンをクリックすると、テキストが「一時停止」に変わり、わずか 1 秒で現在の時刻が再び表示されるようになりました。Ext.TaskManager.stopAll(); を使用しようとしたとき Ext.TaskManager.stop(task) の代わりに動作します! なんで?以下のように私のコード:
<script type="text/javascript">
Ext.onReady (function(){
var config={
msg:'Display Time',
modal:true,
buttons:Ext.Msg.OKCANCEL,
fn:displayTime
}
Ext.MessageBox.msgButtons[0].setText('Start');
Ext.MessageBox.msgButtons[3].setText('Stop');
Ext.MessageBox.show(config);
function displayTime(id){
if(id=='ok'){
var task = {
run:function(){Ext.MessageBox.updateText ('????:' + Ext.util.Format.date(new Date(), 'Y-m-d g:1:s A'));},
interval:1000
}
Ext.TaskManager.start(task);
}
else {
Ext.MessageBox.updateText('Paused!');
Ext.TaskManager.stop(task);
}
};
});