Ender is a full featured package manager for your browser.
It allows you to search, install, manage, and compile front-end JavaScript packages and their dependencies for the web. We like to think of it as npm's little sister.
Ender is not a JavaScript library.
It's not a jQuery replacement. It's not even a static asset. It's a tool for making the consumption of front-end JavaScript packages dead simple and incredibly powerful.
In the browser - small, loosely coupled modules are the future and large, tightly-bound monolithic libraries are the past!
Ender capitalizes on this by offering a unique way to bring together the exciting work happening in JavaScript packages and allows you to mix, match, and customize your own build, suited to your individual needs, without all the extra cruft that comes with larger libraries.
With Ender, if one library goes bad or unmaintained, it can be replaced with another. Need a specific package version? No problem! Does your package have dependencies? Let us handle that for you too!
$ ender build backbone
# installs:
# └─┬ [email protected] - Give your JS App some Backbone with Models, Views, Collections, and Events.
# └── [email protected] - JavaScript's functional programming helper library.
$ ender add domready qwery
# installs:
# ├── [email protected] - bullet proof DOM ready method
# └── [email protected] - blazing fast CSS1|2|3 query selector engine
$ ender remove qwery
# uninstalls:
# └── [email protected] - blazing fast CSS1|2|3 query selector engine
// Require packages to access them as raw packages
var _ = require('underscore')
_.each([1, 2, 3], alert)
// Access methods augmented directly to the $
$.ready(function () {
$([1, 2, null, 3])
.filter(function (item) { return item })
.each(alert)
})
When installing, first make sure you have a working copy of the latest stable version of both Node.js and npm. You can then install Ender with the following single line:
$ [sudo] npm install ender -g
Once installed, you should have access to the ender
command.
The ender
command provides the following actions:
Installs and assembles JavaScript packages and their dependencies.
$ ender build [foo, bar, ...]
Accepts a list of npm package names and/or paths to local packages. If left blank, the directory root will be used.
You can specify a version by suffixing a package with @
followed by a version number.
$ ender build scriptjs [email protected] ../../myLocalPackage
note: When providing a path, the package directory must contain a valid package.json file
- » ender.js - an uncompressed file containing assembled packages
- » ender.min.js - a copy of ender.js, minified by uglify-js
- » local copies of specified packages - located in the node_modules directory, these are used for dependency management
- » --noop - this outputs the assembled packages without the ender-js client api.
- » --output - this outputs your assembled packages to a specified path and filename.
- » --help - gives you more info on the build method.
Installs and appends JavaScript packages and their dependencies to an already assembled library.
$ ender add [foo, bar, ...]
Accepts a list of npm package names and/or paths to local packages.
$ ender add scriptjs
- » ender.js && ender.min.js - Appends package code to already present ender builds
- » local copies of specified packages - located in the node_modules directory, these are used for dependency management
- » --use - Specify which file to append package code to.
- » --help - gives you more info on the add method.
note: You don't need to specify .js when referencing a JavaScript file here
Sets a JavaScript packages to specific version.
$ ender set [email protected]
Accepts a list of npm package names and/or paths to local packages.
$ ender add [email protected]
Uninstalls and removes JavaScript packages and their dependencies from an already assembled library.
$ ender remove [foo, bar, ...]
Accepts a list of npm package names and/or paths to local packages.
$ ender remove domready
- » --use - Specify which file to remove package code from.
- » --help - gives you more info on the remove method.
Rebuilds and reinstalls packages.
$ ender refresh
- » --use - Specify which file to refresh.
- » --help - gives you more info on the refresh method.
Shortcut for compiling code with google closure compiler.
Accepts file paths.
$ ender compile ./header.js ./footer.js ./my/app.js
Provides the current status of your built Ender library. This information includes the build type, a gzipped file size, and a list of all the current packages (with version numbers, descriptions, and dependency tree).
$ ender info
- » --use - tell ender which file to operate on
Looks up keywords against npm's registry and surfaces the most relevant packages. It promotes results for known Ender compatible packages and also generic npm matches).
$ ender search underscore
Gives a simple run through of the available methods and documentation.
$ ender
Because Ender relies on npm for package management -- extending your Ender library is as simple as publishing to npm.
If you haven't already registered your project with npm, create a file called package.json in your package root. A completed package file might look something like this:
{
"name": "blamo",
"description": "a thing that blams the o's",
"version": "1.0.0",
"keywords": ["blamo", "ender"],
"homepage": "http://example.com",
"authors": ["Mr. Blam", "Miss O"],
"repository": {
"type": "git",
"url": "https://github.com/fake-account/blamo.git"
},
"dependencies": {
"klass": "*"
},
"main": "./src/project/blamo.js",
"ender": "./src/exports/ender.js"
}
Have a look at the Qwery package.json file to get a better idea of this in practice.
- » Add the
ender
keyword to your package.json to get promoted by Ender search as a compatible package. - » Add a bridge file for integrating with the Ender client api by specifying an
"ender"
param. - » you may specify
"noop"
for the"ender"
param to tell Ender to not try to integrate it with the Ender client api.
The bridge is an optional JavaScript integration file used to integrate your code with the Ender client api.
The Ender client api offers two powerful ways to interact with your JavaScript packages, a module API which is based on CommonJS Modules spec v1.1 and a heavily augmented $ namespace (like jQuery).
Returns a raw exported JavaScript package.
var myPackage = require('myPackage')
A package name.
var _ = require('underscore') //return the underscore object
If you were to run the following build command ender build backbone
, you could then access both backbone and underscore from your browser like this:
var backbone = require('backbone')
, _ = require('underscore')
backbone.Models(...)
_.each(...)
Ender's module support is also great when you run into libs which are competing for namespace on the $. For example, if package "foo" and package "bar" both expose a method baz
-- you could use require
to gain access to the method being overridden -- as well as set which method you would prefer to be on Ender's internal chain.
$.baz() //executes bar's method baz
$.ender({ baz: require('foo').baz }); // sets $.baz to be foo's method baz
require('bar').baz() //bar's baz is still accessible at any time.
Registers a new public package.
provide("myPackage", myPackageObj)
A package name and a value to store as the package.
provide('underscore', _)
note: Ender automatically wraps all command line installed packages in a closure and makes them available in this way. Because of this, most modules will not be accessible directly in the global scope -- this of course is great news!
Augments arguments onto the Ender client object ($).
An object to augment onto the Ender $. An optional boolean value -- if true, the object will be added to the Internal chain.
$.ender({
myUtility: myLibFn
})
$.myUtility()
note: Within the scope of your extension methods, the internal prototype will be exposed to the developer using the this
context representing the node collection.
$.ender({
rand: function () {
return this[Math.floor(Math.random() * this.length)]
}
}, true)
$('p').rand()
Set the selector engine for the $ object.
A method to be used as the selector engine.
$._select = mySelectorEngine
$('#foo .bar')
note: You can see it in practice in Qwery
If you're building a Mobile Webkit or Android application, you might want to set it simply to querySelectorAll
.
$._select = function (selector, root) {
return (root || document).querySelectorAll(selector)
})
The Jeesh is the official starter pack for Ender. The Jeesh can help you build anything from small prototypes to providing a solid base for large-scale rich application for desktop and mobile devices. At its core, it's a collection of packages that we've found particularly useful for major use-case development endeavors -- but we encourage developers to add
and remove
packages to really make it your own. Currently, the Jeesh includes:
- » domReady - a cross-browser domReady
- » Qwery - a fast light-weight selector engine
- » Bonzo - a bullet-proof DOM utility
- » Bean - a multi-platform event manager
$.domReady(function () {...})
$('#boosh a[rel~="bookmark"]').each(function (el) { ... })
$('#boosh p a[rel~="bookmark"]').hide().html('hello').css({
color: 'red',
'text-decoration': 'none'
}).addClass('blamo').after('✓').show();
$('#content a').bind('keydown input', handler)
$('#content a').emit('customEvent')
$('#content a').remove('click.myClick')
If you're looking to test drive this setup, have a play with the compiled source (minified).
Ender is also a thriving ecosystem of packages, some specifically designed for Ender and others that are simply Ender compatible. To get an idea of what's available, why not have a look at these additional packages:
- » Traversty - a full-featured DOM traversal and collection management utility
- » Reqwest - easy AJAX & form serialization
- » Valentine - type checking, functional iterators and async helpers, JavaScript's Functional Sister
- » Bowser - browser detection
- » Wings - simple templating
- » Morpheus - a brilliant animator
- » Klass - a utility for creating expressive classes
- » Jar - basic cookie handling
Or how about something more substantial? Ender Bootstrap gives you the individual Bootstrap plugins for Ender.
You can find additional modules, or add your own, on the Ender Wiki.
### SELECTOR ENGINESEnder doesn't limit you to using Qwery as your selector engine. You can also choose from:
Instructional videos and other cool stuff for learning about Ender.
<iframe src="http://player.vimeo.com/video/23836209?portrait=0" width="640" height="360" frameborder="0"></iframe> <iframe src="http://player.vimeo.com/video/24296635?portrait=0" width="640" height="360" frameborder="0"></iframe>We would love to hear how you're using Ender or why you're not. What you love... what you hate... And we would love all the help we can get! Got a great idea? Open an issue, submit a pull request, follow @ender, or message us on twitter!
Ender is licensed under MIT - copyright 2011-2013 Dustin Diaz, Jacob Thornton, Rod Vagg
For the individual modules, see their respective licenses.