0.1.1 • Published 9 years ago
spa_command v0.1.1
Spa Command
A simple way to bind commands.
Installation
npm install spa_command --saveBind a command with a function
spa.binder.bindCommand("mycommand", function (e) {
           
});<button data-event="click:mycommand">My command</button>Bind a command with an object (object with only commands or a view model for example)
var vm = {
    title: "My title",
    mycommand1: function (e) {
        console.log(this); // context vm
        // access to the context
        this.title = "My new title";
    },
    mycommand2: function (e) {
        console.log("mycomand2",e);
    },
};
spa.binder.bindCommands(vm); <button data-event="click:mycommand1">My command 1</button>Multiples events
The command will be raised on "blur" (lost focus) and "keypress" for example
<input type="text" data-event="blur:mycommand2;keypress:mycommand2" />config
- scope : by default is "body". Could be change by selector (example "#mydiv") or with the html element
- eventAttribute : by default "data-event"
- context : allow to change the context of the command
- except : allow to ignore elements
- extra : allow to pass extra data
Example:
all html elements with the class "not-bind" will be ignored.
spa.binder.bindCommands(vm, {
    except: [".not-bind"],
    extra: {
        value: "my value"
    }
});