日期:2014-05-16  浏览次数:20322 次

Extjs关于alert显示不出—异步问题


对应extjs提示框不能正常显示,而使用js的本身提示框可以正常,但由于样式不统一,不是
好的解决方法。

解决该问题,要了解extjs异步原理。

ext的提示框都是异步的,非阻塞模式的,浏览器js的提示框是同步的,即是阻塞模式的。

也就是说:

Ext版的alert是异步执行,Ext.MessageBox.confirm()为异步。
JavaScript引擎是单线程的,强制所有的异步事件排队等待执行。

异步执行是指Ext.Msg.confirm调用后不停留,继续执行下面的代码。
而回调在其它的JS执行任务中被调用,在回调函数实现同步。

Ext.Msg.alert 是异步的;
无论是否执行此句语句,调用后不停留,程序都先走下一句js语句。
而 js的alert是同步的,执行时系统会挂起等待用户输入。

例子:
Ext.MessageBox.confirm("提示","门票修改成功!");
window.win.close();
出现IE运行结果:没有提示,页面直接关闭。

正确的使用是采用回调函数,在回调函数运行接下来js语句:
Ext.MessageBox.confirm("提示","门票修改成功!",function(btn){
window.win.close();})

另外ext中store的load()、reload()也是异步,同样需要经过回调函数解决代码执行顺序
问题。