dojo.Stateful¶
Authors: | Kris Zyp, Marcus Reimann |
---|---|
Project owner: | Kris Zyp |
since: | V1.5 |
A new generic interface and base class for getting, setting, and watching for property changes (with getters and setters) in a consistent manner.
Introduction¶
dojo.Stateful provides the ability to get and set named properties in conjunction with the ability to monitor these properties for changes. dojo.Stateful is intended to be a base class that can be extended by other components that wish to support watchable properties. This can be very useful for creating live bindings that utilize current property states and must react to any changes in properties.
Usage¶
Dojo 1.7 (AMD)¶
require(["dojo/Stateful"], function(Stateful){
// create a new Stateful object:
var myObj = new Stateful();
// watch changes of property 'foo':
myObj.watch("foo", function(){
console.log("foo changed to " + myObj.get("foo"));
});
// test: change obj.foo:
myObj.set("foo", "bar");
});
Dojo < 1.7¶
dojo.require('dojo.Stateful');
// create a new Stateful object:
var myObj = new dojo.Stateful();
// watch changes of property 'foo':
myObj.watch("foo", function(){
console.log("foo changed to " + myObj.get("foo"));
});
// test: change obj.foo:
myObj.set("foo", "bar");
Available Methods¶
-
Get a property on a Stateful instance. *new in 1.5*
-
Set a property on a Stateful instance. *new in 1.5*
-
Watches a property for changes. *new in 1.5*
Examples¶
get¶
Get a property on a Stateful instance. *new in 1.5*
Get a named property on a Stateful object. The property may potentially be retrieved via a getter method in subclasses. In the base class this just retrieves the object’s property.
// dojo 1.7 (AMD)
require(["dojo/Stateful"], function(Stateful){
// create a new Stateful object with foo = 3:
var myObj = new Stateful({foo: 3});
// call the getter for property 'foo':
myObj.get('foo'); // returns 3
// alternative syntax:
myObj.foo; // returns 3
});
// dojo < 1.7
// create a new Stateful object with foo = 3:
var myObj = new dojo.Stateful({foo: 3});
// call the getter for property 'foo':
myObj.get('foo'); // returns 3
// alternative syntax:
myObj.foo; // returns 3
set¶
Set a property on a Stateful instance. *new in 1.5*
Sets named properties on a stateful object and notifies any watchers of the property. A programmatic setter may be defined in subclasses.
// dojo 1.7 (AMD)
require(["dojo/Stateful"], function(Stateful){
// create a new Stateful object:
var myObj = new dojo.Stateful();
// watch changes of each property:
myObj.watch(function(name, oldValue, value){
// this will be called on the set below
}
myObj.set(foo, 5);
});
// dojo < 1.7
// create a new Stateful object:
var myObj = new dojo.Stateful();
// watch changes of each property:
myObj.watch(function(name, oldValue, value){
// this will be called on the set below
}
myObj.set(foo, 5);
set() may also be called with a hash of name/value pairs, ex:
// dojo 1.7 (AMD)
require(["dojo/Stateful"], function(Stateful){
// create a new Stateful object:
var myObj = new Stateful();
// The following is equivalent to calling
// set(foo, "Howdy") and set(bar, 3):
myObj.set({
foo: "Howdy",
bar: 3
});
});
// dojo < 1.7
// create a new Stateful object:
var myObj = new dojo.Stateful();
// The following is equivalent to calling
// set(foo, "Howdy") and set(bar, 3):
myObj.set({
foo: "Howdy",
bar: 3
})
watch¶
Watches a property for changes. *new in 1.5*
Parameters:
- name:
- Indicates the property to watch. This is optional (the callback may be the only parameter), and if omitted, all the properties will be watched
- callback:
- The function to execute when the property changes. This will be called after the property has been changed. The callback will be called with the this set to the instance, the first argument as the name of the property, the second argument as the old value and the third argument as the new value.
- returns:
- An object handle for the watch. The unwatch method of this object can be used to discontinue watching this property:
// dojo 1.7 (AMD)
require(["dojo/Stateful"], function(Stateful){
// create a new Stateful object:
var myObj = new Stateful();
// watch changes of property 'foo':
var watchHandle = myObj.watch("foo", callback);
// ...
// discontinue watching this property:
watchHandle.unwatch(); // callback won't be called now
});
// dojo < 1.7
// create a new Stateful object:
var myObj = new dojo.Stateful();
// watch changes of property 'foo':
var watchHandle = myObj.watch("foo", callback);
// ...
// discontinue watching this property:
watchHandle.unwatch(); // callback won't be called now
See also¶
- dijit._Widget.set/get a setter or getter for properties of Dijits
- Introductory article on dojo.Stateful - http://www.sitepen.com/blog/2010/05/04/consistent-interaction-with-stateful-objects-in-dojo/