Zaczynam tworzyć nową aplikację Titanium i chcę korzystać z najlepszych praktyk i unikać przecieków pamięci od samego początku. Jestem nowy w CommonJS, a także w całej platformie Titanium.Proszę polecić tytanową strukturę projektu przy użyciu CommonJS
Niestety wydaje się, że wszystkie przykładowe aplikacje dla tytanu surround na Ti.include("/lib/module")
zamiast newer recommended best practice z require("/lib/module")
.
Obawiam się, że użycie pamięci CommonJS może wymagać użycia pamięci. Z wersji CommonJS Modules in Titanium documentation wynika, że moduły będą buforowane, czy nie oznacza to, że jeśli kiedykolwiek uzyskam dostęp do modułu, wszystkie te funkcje nagle pozostaną w pamięci, nawet jeśli wykroczą poza zakres?
zacząłem nową aplikację o następującej strukturze
/ctrl # Model/UI controllers
/lib # libraries (common + 3rd party)
/ui # UI forms
/model # DAL objects for data store
Stąd mój główny app ma pojedynczy widok styl deski rozdzielczej, która jest luźno następującą strukturę:
(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();
})();
Wszelkie wytyczne dotyczące poprawna struktura projektu jest bardzo doceniana.
To idealne, struktura projektu jest dokładnie tym, za czym byłem. –