1

タイトルバーでボタンを機能させようとするのは少し難しくなっています。現在、ボタンはクリックすると開き (webview でウィンドウを呼び出します)、html ボタンをクリックすると閉じます。しかし、一度だけ。問題は、ウィンドウが閉じられた後、タイトルバーのボタンがウィンドウを再び開かないように見えることです...

これはおそらく単純なエラーですが、答えを見つけるのが難しいエラーです。

私のapp.js:

var infoBtn = Titanium.UI.createButton({
    title:'Info'
});

// ABOUT
var win0 = Titanium.UI.createWindow();

var webview0 = Titanium.UI.createWebView({url: 'about.html'});

infoBtn.addEventListener('click', function() { win0.open(); });
Ti.App.addEventListener('closeAbout', function() { win0.close(); });

win0.add(webview0);
win0.hideNavBar();

私のabout.html:

<head>
<script type="text/javascript" charset="utf-8">
function closeAboutBtn() {
    Ti.App.fireEvent('closeAbout');
}
</script>
</head>

<body>
<a href="#" class="btn" onClick="closeAboutBtn(); return false;">Return to App</a>
</body>

毎回押されたときにアバウトボタンがコンテンツを表示するように修正する方法について誰かアイデアがありますか?

4

1 に答える 1

1

最初の迅速な対応は、ウィンドウを閉じるのではなく、単に「非表示」にすることです。

検証済み:

私が一貫して彼のウィンドウを非表示にして表示することができた唯一の方法は次のとおりです

// listener assigned to info button
infoBtn.addEventListener('click', function() { 
    Ti.API.log('info button clicked, show window');
    win2.open(); 
    win2.show(); 
});

// Listener assigned to close in about window
Ti.App.addEventListener('closeAbout', function(data) { 
    Ti.API.log('info button clicked, close window');
    win2.close(); 
    win2.hide();
});
于 2010-11-03T17:48:13.877 に答える