JavaScript Module Strategies
Presented by: Ian McPhail
What is a Module?
// Object Literal
var MyModule = {
property: 'someValue',
method: function () { }
};
// Module Pattern
var Module = (function () {
// Private state
var privateVar,
privateMethod;
privateMethod = function() { };
// Public state
return {
publicVar: 'someValue',
publicMethod: function() { }
};
})();
Why use Modules?
- Code organization
- Encapsulation
- Dependency management
- Optimization
- Reusability
- Collaboration
Global Variables
// app.js
var App = {};
// Code goes here
window.App = App;
// cart.js
function Cart() { }
App.Cart = new Cart();
// overlay.js
function Overlay() { }
App.Overlay = new Overlay();
Pros
- Native browser support
- Easy to implement
- No build step
- Faster initial load time
Cons
Global Variables
- Not scalable
- Fragile code
- Manual dependencies
- Global lookup performance
AMD
// app.js
require(['lib/jquery', './cart', './overlay'], function($, Cart, Overlay) {
// Code goes here
});
// cart.js
define(['lib/jquery'], function($) {
function Cart() { }
return new Cart();
});
// overlay.js
define(['lib/jquery'], function($) {
function Overlay() { }
return new Overlay();
});
- Designed for the browser
- No build step required
- Asynchronous loading
- Flexible format
- Explicit dependencies
- Plugin support
AMD
- Verbose syntax
- Requires script loader
- Extensive configuration
- Asynchronous execution
Pros
Cons
CommonJS
// app.js
var $ = require('jquery');
var Cart = require('./cart');
var Overlay = require('./overlay');
// Code goes here
// cart.js
var $ = require('jquery');
function Cart() { }
module.exports = new Cart();
// overlay.js
var $ = require('jquery');
function Overlay() { }
module.exports = new Overlay();
- Adopted by Node.js
- Access to NPM ecosystem
- Convenient syntax
- Synchronous execution
CommonJS
- Built for the server
- Build tools required
- Large module bundles
- Synchronous loading
Pros
Cons
ES6 Modules
// app.js
import $ from 'lib/jquery';
import Cart from './cart';
import Overlay from './overlay';
// Code goes here
// cart.js
import $ from 'lib/jquery';
function Cart() { }
export default new Cart()
// overlay.js
import $ from 'lib/jquery';
function Overlay() { }
export default new Overlay()
- Future proof
- Nice, compact syntax
- Static module structure
- Live bindings
- Asynchronous / synchronous loading
ES6 Modules
- Still new
- Build tools required
- Module Loader spec
Pros
Cons
Thanks!
JavaScript Module Strategies
By webguyian
JavaScript Module Strategies
- 791