【问题标题】:Cannot stop running task when call Ext.TaskManager.stop() method调用 Ext.TaskManager.stop() 方法时无法停止正在运行的任务
【发布时间】:2012-04-19 02:23:13
【问题描述】:

我设置了一个消息框来显示当前时间。定时器间隔设置为 1000,有 2 个按钮来启动和停止“定时器”。当单击“停止”按钮时,它会调用 Ext.TaskManager.stop 方法并将消息框中的文本更新为“暂停”。但是,当单击“停止”按钮并且文本变为“暂停”仅一秒钟时,它又变回显示当前时间。当我尝试使用 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);
            }    
    };       
    });

【问题讨论】:

    标签: extjs task taskmanager


    【解决方案1】:

    任务是在 if 中定义的,所以当遇到 else 时,它​​实际上是在运行 Ext.TaskManager.stop(),这不会停止您的任务。将您的任务移到函数声明之外。

            var task = {
                run: function () {
                    Ext.MessageBox.updateText('????:' + Ext.util.Format.date(new Date(), 'Y-m-d g:1:s A'));
                },
                interval: 1000
            }
    
    
            function displayTime(id) {
                if (id == 'ok') {
                    Ext.TaskManager.start(task);
                } else {
                    Ext.MessageBox.updateText('Paused!');
                    Ext.TaskManager.stop(task);
                }
            };
    

    【讨论】:

      猜你喜欢
      • 2014-10-19
      • 1970-01-01
      • 2014-02-27
      • 2022-01-01
      • 1970-01-01
      • 2012-11-21
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多