Skip to content

Latest commit

 

History

History
100 lines (92 loc) · 3.76 KB

README.md

File metadata and controls

100 lines (92 loc) · 3.76 KB

jquery-autosave

// simple
$("input").autosave();

Watches change events on all inputs, POST-ing their values to your backend.

// awesomeness
$(".autosave").autosave({ url:"/save", done:function(){}, fail:function(){} });

Use a class and when those elements change, they will POST their values and data-* attrs to your url and include callbacks just like $.ajax

Options

The following options can be passed to the plugin when it is initialized.

Option Type Default Description
url string null The URL to which the request is sent.
method string "POST" The type of request to make, usually POST or GET. Other HTTP request methods, such as PUT and DELETE, can also be used here, but they are not supported by all browsers.
event string "change" Event that causes the plugin to send data to your url. See jQuery.on for options.
type string "html" Specify the dataType you are expecting (xml, json, script, or html)
data object null Object that holds all data that will be posted back to the url when the event is fired. You can set global default values to be sent here. All data-* attribute values end up here, minus "data-" (e.g. "data-foo" becomes "foo").
debug boolean false Will stop any requests from being performed and will console.log the data variable inside of the autosave library

##Callbacks/Promises The following promise methods are available. However, if used, they should be included as options when autosave is initialized. See demos below for implementation example.

Callback Description
before: function(){} Called just before processing the autosave. This is a great place to make some last second changes to the inline html data-* attributes.
done: function(data, textStatus, jqXHR){} Called when the autosave ajax call was successful.
The function's arguments are the same as those in a jqXHR.done() in jQuery.ajax (data, textStatus, and the jqXHR object).
fail: function(jqXHR, textStatus, errorThrown){} Called when the autosave ajax call failed or there is an error in the response. Note: Default 'type' is 'html' and it must match the response or even a 200(OK) status response will show as failed.
The function's arguments are the same as those in a jqXHR.fail() in jQuery.ajax (jqXHR, textStatus, errorThrown).
always: function(){} Called when finished, whether successful or not. This is the very last process performed during an autosave.

originally forked from cfurrow/jquery.autosave.js at https://github.com/cfurrow/jquery.autosave.js