Я начинаю новое приложение Titanium и хочу использовать лучшие практики и избегать утечек памяти с самого начала. Я новичок в CommonJS, а также в платформе Titanium в целом.Пожалуйста, порекомендуйте структуру проекта титана, используя CommonJS
К сожалению, все образцы образцов для титана окружают на Ti.include("/lib/module")
вместо newer recommended best practice от require("/lib/module")
.
Что меня беспокоит, так это может потребоваться использование памяти с использованием CommonJS. Из CommonJS Modules in Titanium documentation в нем указано, что модули будут кэшироваться, не означает ли это, что если я когда-нибудь получу доступ к модулю, который все эти функции внезапно останутся в памяти, даже если они выйдут из области видимости?
Я начал новое приложение со следующей структурой
/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();
})();
Любое руководство по правильная структура проекта очень ценится.
Это прекрасно, структура проекта - именно то, что я был после. –