Minimalistic JavaScript module system for browsers.
micromodules is a good way to organize browser code when using mastodon-like libraries and/or tooling is less desirable option. It does not load JS files for you but rather helps you to keep your code into meaningfull and reusable modules. micromodules weights only ~900B compressed and is suitable for placing into document's head or anywhere else.
Place the code anywhere before first usage. Even that is not strictly required, which will be explained soon.
A module is declared with declare
function call.
declare('name', 'John Doe');
Any data type is allowed
declare('num', 111);
declare('bool', false);
declare('Sysprops', {key:'value'});
Any number of modules may be declared in single file. Modules that need setup functions may be declared like following: (AMD style)
declare('MoreComplexModule', function(include){
//doing some computation
//and
return 'some value';
});
It is good time to say more about declaring module with setup function. Setup function in the example above is not called until first time include
d and never again. That means:
1. If you need reusable function from declared module defining inside setup function and returning it is the way to go:
declare('ComplexMethod', function(include){
//doing some computation
//and
return function(){
};
});
2. If you pass function as an argument to declare
it will be executed and return value will be used as module value. So, for example, things like jQuery
, which are actually functions, would have to be declared like this:
declare('jQuery', function(include){
return jQuery
});
(this is by no means niether only nor the best way yo store jQuery and friends as modules).
If your prefer to declare modules immidiately (for example) in document's head and to include micromodule library code after that, you have an option of using 'inline' modules declaration, like following:
<script type="text/n" data-md="inline1">
// regular JS code
// and return statement as if we are inside function's body
return "A value of some 'inline module'";
</script>
Requirements are that script
's attribute type
is set to ignorable value (antyhing other than "module"
(ES6) or "text/javascript"
) and data-md
attribute is set to module's id. This way, module will be registered whenever micromodule library code occurs.
Module may be deleted with declare.remove
function call:
declare.remove('modname');
Module is used with include
function call:
var name = include('name');
A module has to be declared previously, of course:
var nonExistingMod = include('nonExistingMod'); // undefined
include
is available as first argument in declare
setup function:
declare('mod_name', function(include){
var name = include('name');
// note: this === window in setup functions
})
There is a useful option of storing a global variable into micromodules module system and subsequent including:
var Raf = include('requestAnimationFrame+');
var jQuery = include('jQuery+');
This option is triggered with the last character of identifier set to +
, which means, if there is no requested module name, before giving up, try to search global variables and import them if founded.
This way we will have globals as local vars pulled from module system.