Что это? Зачем и для кого? Как пользоваться?
- Асинхронный require модулей
- Асинхронный provide модулей
- Возможность передекларации/додекларации модуля
Смотри пункты 1, 2 и 3 требований
Смотри пункты 2 и 3 требований
void modules.define(
String moduleName,
[String[] dependencies],
Function(
Function([Object objectToProvide], [Error error]) provide,
[Object resolvedDependency, ...],
[Object previousDeclaration]
) declarationFunction
)
void modules.require(
String[] dependencies,
Function([Object resolvedDependency, ...]) successCallbackFunction,
[Function(Error error) errorCallbackFunction]
)
Modules modules.create()
void setOptions(Object options)
trackCircularDependencies
- приfalse
не проверяет зацикленные зависимости. По умолчаниюtrue
allowMultipleDeclarations
- приfalse
запрещает расширение (переопределение) модулей и генерирует ошибку. По умолчаниюtrue
String getState(String name)
NOT_DEFINED
- не было объявления модуляNOT_RESOLVED
- модуль был объявлен, но разрешение зависимостей еще не начатоIN_RESOLVING
- в процессе разрешения зависимостей модуляRESOLVED
- зависимости разрешены
Boolean isDefined(String moduleName)
modules.define(
'A',
['B', 'C'],
function(provide, b, c, prev) {
var a = {};
provide(a);
});
modules.define(
'B',
function(provide) {
var b = {};
provide(b);
});
modules.define(
'C',
['B'],
function(provide, b) {
var c = {};
provide(c);
});
modules.define(
'C',
function(provide, prevC) {
var nextC = {};
provide(nextC);
});
modules.require(
['A'],
function(a) {
// module 'A' now resolved to a
});