原文地址:http://www.sencha.com/blog/top-support-tips-december-2013?mkt_tok=3RkMMJWWfF9wsRolu63MZKXonjHpfsX57uwtUae2i4kz2EFye%2BLIHETpodcMTcNnMa%2BTFAwTG5toziV8R7PCKM1338YQWhPj
作者:Sencha Support Team
有时候,重用正在运行的可以启动和暂停的的任务非常有用。相当幸运,在Ext JS中实现可重用的任务相当容易。Ext.util.TaskManager 是一个单例模式(singleton)的类,它的start方法可以通过传递的配置自动创建任务。或者,也可以创建自己的任务实例。任务会保持一个内部运行的根据间隔时间自动增长的计数器,且可在每次调用start方法进行重置。可以为任务定义一个在任务停止(或取决于如何缓存进度的暂停)时调用的onStop函数。使用fireOnStart配置项可以用来判断任务在调用start方法或在第一次时间间隔过后run函数是否执行正确。
这里有一个创建计时器并允许用户启动和暂停它的示例。任务的进度被缓存它的值属性指向的counter组件中。现在,每当调用stop方法就像暂停这个用例。
可以在https://fiddle.sencha.com/#fiddle/1ca来查看它的行为。
如果想阅读更多有关任务间隔(Taskk Intervals)的文档,可参阅http://docs.sencha.com/extjs/4.2.2/#!/api/Ext.util.TaskRunner。
你知道吗,即使没有在MVC应用程序中使用控制器,容器也可以监听子组件的事件?有两种方法可以实现这个:
Ext.Viewport.add({ layout : { type : 'card', animation : 'slide' }, items : [ { html : 'Card One', items : [ { xtype : 'button', ui : 'forward', text : 'View Details' } ] } ], listeners : { delegate : 'button[ui=forward]', tap : function(button, e) { this.setActiveItem({ html : 'Details are here!' }); } } });
Ext.define('MyContainer', { extend : 'Ext.Container', xtype : 'mycontainer', config : { layout : { type : 'card', animation : 'slide' }, items : [ { html : 'Card One', items : [ { xtype : 'button', ui : 'forward', text : 'View Details' } ] } ], control : { 'button[ui=forward]' : { tap : 'onButtonTap' } } }, onButtonTap : function(button, e) { this.setActiveItem({ html : 'Details are here!' }); } }); Ext.Viewport.add({ xtype : 'mycontainer' });
Ext.Viewport.add({ html : '<div>You can capture tap event on this <a href="#" class="tappable">link</a> in your components</div>', listeners : { element : 'element', delegate : 'div a.tappable', tap : function(e, t) { e.stopEvent(); Ext.Viewport.removeAll(); Ext.Viewport.setHtml('You tapped it!'); } } });
Sencha Cmd严重依赖于一组已知的有关你的环境变量和应用程序的内部属性。这些属性包括软件路径、系统设置和Sencha软件版本。
在命令行中,只要在项目根目录中输入以下命令就可以查看和使用这些信息:
sencha diag show
想了解更多有关将这些属性继承到自定义脚本的信息,可参阅: http://docs.sencha.com/extjs/4.2.2/#!/guide/command_advanced