Модули Appcelerator и CommonJS (кэширование и циклические ссылки)
Вот эта вещь:
Я использую способ CommonJS, чтобы сделать мое мобильное (iPhone / Android) приложение модульным. Там нет ничего удивительного. Но есть одна вещь, которую я просто не могу понять.
CommonJS позволяет мне создавать приватные переменные STATIC, что позволяет легко создавать синглтоны. Это, я думаю, по крайней мере, потому, что содержимое файла, который получаетrequire()
d читается только один раз, а затем каждый раз возвращается объект экспорта (который инициализируется только один раз).
Но когда я создаю циклическую ссылку, как показано ниже, код внутри включенного модуля выполняется каждый раз.
Wait...
Забавно, что, когда я пишу этот вопрос, я внезапно осознаю, что ни один из призывов кrequire()
закончите до начала следующего (следовательно, переполнение стека показано ниже).
Есть мысли о том, нахожусь ли я на трассе или нет? Здесь уже прошло 5 часов утра, так что все ставки сняты, насколько я понимаю: D.
EXAMPLES:
Посмотрите этот кусок кода, он определяет синглтон:
/* Singleton.js */
exports.getSingleton = getSingleton;
function getSingleton(name) {
if (!instance) {
instance = new Thing(name);
}
return instance;
}
function Thing(name) {
this.name = name;
}
var instance;
яrequire()
этот файл как таковой:
var theFirstThing = require('Singleton').getSingleton('first');
Ti.API.info('first: ' + theFirstThing.name)
var possiblyAnotherOtherThing = require('Singleton').getSingleton('second');
Ti.API.info('second: ' + possiblyAnotherOtherThing.name);
Выход:
[DEBUG] loading: /path/to/sim/MyApp.app/app.js, resource: app_js
[DEBUG] loading: /path/to/sim/MyApp.app/Singleton.js, resource: Singleton_js
[INFO] first: first
[INFO] second: first
Почему циркулярные ссылки, подобные приведенным ниже, не работают? (Я, возможно, уже ответил на этот вопрос, прокомментируйте / ответьте, если хотите).
app.js
require('Banana');
Pinapple.js
require('Banana');
Banana.js
require('Pineapple');
Потому что вывод таков:
[DEBUG] loading: /path/to/simulator/MyApp.app/app.js, resource: app_js
[DEBUG] loading: /path/to/simulator/MyApp.app/Banana.js, resource: Banana_js
[DEBUG] loading: /path/to/simulator/MyApp.app/Pineapple.js, resource: Pineapple_js
[DEBUG] loading: /path/to/simulator/MyApp.app/Banana.js, resource: Banana_js
[DEBUG] loading: /path/to/simulator/MyApp.app/Pineapple.js, resource: Pineapple_js
[DEBUG] loading: /path/to/simulator/MyApp.app/Banana.js, resource: Banana_js
[DEBUG] loading: /path/to/simulator/MyApp.app/Pineapple.js, resource: Pineapple_js
[DEBUG] loading: /path/to/simulator/MyApp.app/Banana.js, resource: Banana_js
/* etcetera (total of 15 times back and forth) */
[DEBUG] loading: /path/to/simulator/MyApp.app/Pineapple.js, resource: Pineapple_js
[DEBUG] loading: /path/to/simulator/MyApp.app/Banana.js, resource: Banana_js
[DEBUG] loading: /path/to/simulator/MyApp.app/Pineapple.js, resource: Pineapple_js
[ERROR] Script Error = Maximum call stack size exceeded. (unknown file)