base-methods data:image/s3,"s3://crabby-images/1aa38/1aa389d1a35666b0edccc85d71eedc2e2d33cd82" alt="NPM version"
Starter for creating a node.js application with a handful of common methods, like set
, get
, and del
.
Great way to start building a highly modular, unit testable and pluggable node.js application!
Install
Install with npm
$ npm i base-methods --save
Usage
var base = require('base-methods');
inherit
function App() {
base.call(this);
}
base.extend(App);
var app = new App();
app.set('a', 'b');
app.get('a');
instantiate
var app = base();
app.set('foo', 'bar');
console.log(app.foo);
Inherit or instantiate with a namespace
A .namespace()
method is exposed on the exported function to allow you to create a custom namespace for setting/getting on the instance.
var Base = require('base-methods')
var base = Base.namespace('cache');
var app = base();
app.set('foo', 'bar');
console.log(app.cache.foo);
API
Create an instance of Base
with options
.
Params
Example
var app = new Base();
app.set('foo', 'bar');
console.log(app.get('foo'));
Define a plugin function to be called immediately upon init. Plugins are chainable and the only parameter exposed to the plugin is the application instance.
Params
fn
{Function}: plugin function to callreturns
{Object}: Returns the item instance for chaining.
Example
var app = new Base()
.use(foo)
.use(bar)
.use(baz)
Assign value
to key
. Also emits set
with the key and value.
Params
key
{String}value
{any}returns
{Object}: Returns the instance for chaining.
Example
app.on('set', function(key, val) {
});
app.set(key, value);
app.set({name: 'Halle'});
app.set([{foo: 'bar'}, {baz: 'quux'}]);
console.log(app);
Return the stored value of key
. Dot notation may be used to get nested property values.
Params
Example
app.set('a.b.c', 'd');
app.get('a.b');
app.get(['a', 'b']);
Return true if app has a stored value for key
, false only if typeof
value is undefined
.
Params
Example
app.set('foo', 'bar');
app.has('foo');
Delete key
from the instance. Also emits del
with the key of the deleted item.
Params
key
{String}returns
{Object}: Returns the instance for chaining.
Example
app.del();
app.del('foo');
app.del(['foo', 'bar']);
Define a non-enumerable property on the instance.
Params
key
{String}value
{any}returns
{Object}: Returns the instance for chaining.
Example
define('render', function(str, locals) {
return _.template(str)(locals);
});
Visit method
over the items in the given object, or map
visit over the objects in an array.
Params
method
{String}val
{Object|Array}returns
{Object}: Returns the instance for chaining.
Mix property key
onto the Base prototype. If base-methods
is inherited using Base.extend
this method will be overridden
by a new mixin
method that will only add properties to the
prototype of the inheriting application.
Params
key
{String}val
{Object|Array}returns
{Object}: Returns the instance for chaining.
Static method for adding global plugin functions that will be added to an instance when created.
Params
fn
{Function}: Plugin function to use on each instance.
Example
Base.use(function(app) {
app.foo = 'bar';
});
var app = new Base();
console.log(app.foo);
Static method for inheriting both the prototype and
static methods of the Base
class. See class-utils
for more details.
Similar to util.inherit
, but copies all static properties,
prototype properties, and descriptors from Provider
to Receiver
.
class-utils for more details.
Plugins
There are a number of different plugins available for extending base-methods. Let us know if you create your own!
- base-cli: Plugin for base-methods that maps built-in methods to CLI args (also supports methods from a… more | homepage
- base-config: base-methods plugin that adds a
config
method for mapping declarative configuration values to other 'base'… more | homepage - base-data: adds a
data
method to base-methods. | homepage - base-fs: base-methods plugin that adds vinyl-fs methods to your 'base' application for working with the file… more | homepage
- base-options: Adds a few options methods to base-methods, like
option
, enable
and disable
. See the readme… more | homepage - base-pipeline: base-methods plugin that adds pipeline and plugin methods for dynamically composing streaming plugin pipelines. | homepage
- base-plugins: Upgrade's plugin support in base-methods to allow plugins to be called any time after init. | homepage
- base-store: Plugin for getting and persisting config values with your base-methods application. Adds a 'store' object… more | homepage
Tests
Running tests
Install dev dependencies:
$ npm i -d && npm test
Coverage
Statements : 100% (15/15)
Branches : 100% (2/2)
Functions : 100% (2/2)
Lines : 100% (15/15)
Contributing
Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.
Author
Jon Schlinkert
License
Copyright © 2015 Jon Schlinkert
Released under the MIT license.
This file was generated by verb-cli on November 17, 2015.