我目前正在开发 iPad 应用程序并遇到以下问题。
当我试图打开一个包含一组按钮的新窗口时,这些按钮是在循环中创建的,在转换期间只有第一个按钮可见,其余的将在新窗口可见后呈现。看起来很糟糕,我想不出一种方法来“等待”滑动,直到一切就绪(有点像 jquery 的准备好,或者加载 DOM 元素时的回调)。
这就是我正在做的事情:
clicker.addEventListener('click', function(e){
var overview = Ti.UI.createWindow( {
title : "Overview",
barColor: '#000',
layout : 'vertical',
url: '/views/overview.js',
_parent: Titanium.UI.currentWindow,
navGroup : navGroup,
rootWindow : win1
});
navGroup.open(overview, {animated:true});
});
在overview.js 中,我执行以下操作:
var overviewdata = [/*some data*/];
for(var i = 0;i < overviewdata.length;i++){
//calculations for proper positioning
if(i == 0 || i%4 == 0){
toppx = 30;
leftpx = 40;
}
else
{
leftpx += 245;
toppx = -200;
}
overviewbttns[i] = Ti.UI.createButton({
title: overviewdata[i].title,
backgroundImage:"/images/views/button.png",
width: 200,
height: 200,
left: leftpx,
top: toppx,
id: i
});
//add to window
win.add(overviewbttns[i]);
//attach event handler
overviewbttns[i].addEventListener('click',function(e){
var w = Ti.UI.createWindow( {
title : overviewdata[e.source.id].title,
barColor: '#000',
layout : 'vertical',
url: "/views/"+overviewdata[e.source.id].jsfile,
_parent: Titanium.UI.currentWindow,
navGroup : win.navGroup,
rootWindow : win.rootWindow
});
win.navGroup.open(w);
});
}
那么,有没有办法在概览窗口完全呈现时获取回调/事件?
任何提示表示赞赏,我真的被困在这里。
提前致谢!