新しい Titanium アプリを開始していますが、ベスト プラクティスを使用して、最初からメモリ リークを回避したいと考えています。私は、CommonJS だけでなく、Titanium プラットフォーム全般も初めて使用します。
残念ながら、チタン サラウンドのすべてのサンプル アプリケーションは、新しい推奨ベスト プラクティスのTi.include("/lib/module")
代わりにオンになっているようです。require("/lib/module")
私が心配しているのは、CommonJS を使用する際のメモリ消費量です。CommonJS Modules in Titaniumのドキュメントでは、モジュールがキャッシュされると記載されていますが、これは、モジュールにアクセスすると、それらの関数が範囲外になっても突然メモリ内に留まるということではないでしょうか?
次の構造の新しいアプリを開始しました
/ctrl # Model/UI controllers
/lib # libraries (common + 3rd party)
/ui # UI forms
/model # DAL objects for data store
ここから、私のメイン アプリには、次のように大まかに構成された単一のダッシュボード スタイル ビューがあります。
(function() {
var getMenuItem = require("/ui/main").getMenuItem;
var win = Titanium.UI.createWindow({
title:'Main',
backgroundColor:'#fff'
});
var nav = Ti.UI.iPhone.createNavigationGroup({
window:win
});
var sect;
var data = [];
sect = Ti.UI.createTableViewSection();
data.push(sect);
sect.add(getMenuItem("Customers",
require("/ctrl/account").createCustMainWindow));
sect.add(getMenuItem("Schedules",
require("/ctrl/schedule").createScheduleMainWindow));
sect.add(getMenuItem("Settings"));
var menu = Titanium.UI.createTableView({
style: Ti.UI.iPhone.TableViewStyle.GROUPED,
data:data
});
win.add(menu);
menu.addEventListener('click',function(e) {
if (e.rowData.createWindow) {
var win = e.rowData.createWindow(nav);
nav.open(win);
}
});
var navWindow = Titanium.UI.createWindow();
navWindow.add(nav);
navWindow.open();
})();
正しいプロジェクト構造に関するガイダンスは大歓迎です。