Skip to content

Latest commit

 

History

History
74 lines (55 loc) · 1.81 KB

README.md

File metadata and controls

74 lines (55 loc) · 1.81 KB

jsDecision

This is a very simple jQuery event decision wrapper.

#Usage

Click Decision

      <div id="deleteUser">
         <button data-decision="yes">yes</button>
         <button data-decision="no">no</button>
      </div>
      
      var deleteUser = new decision( '#deleteUser' );

      deleteUser.click().define('yes',function(event){
        alert('yes');
      }).define('no',function(event){
        alert('no');
      });

Same decision but using a different attribute identifier

      deleteUser.click('data-some-other-attribute').define('yes',function(event){});

Change decision, with a defined context for 'this'

      <select name="car">
         <option value=""></option>
         <option value="honda">Honda</option>
         <option value="lexus">Lexus</option>
      </select>

      var obj = { yell: function(){ alert('ahhh'); } };

      var carSelect = new decision('[name=car]');

      carSelect.change( 'select' ).define('lexus', function(){
        alert('lexus');
        this.yell();
      }, obj);

Input Radio/Checkbox decisions

      <label> <input type="radio" name="cause" value="support" /> Support </label>
      <label> <input type="radio" name="cause" value="unsupported" /> Unsupported </label>

      var causeRadio = new decision('[name=cause]');

      causeRadio.change( 'radio' ).define('support', function(){
        alert('I support the cause');
      }).define('unsupported', function(){
        alert('I don\'t support the cause');
      });
      

Decisions can also be defined with an object

      causeRadio.change( 'radio' ).define({
            support: function(){},
            unsupported:function(){}
            '*': function(){} 
      }, context );
      

'*' functions execute on all decisions