Define rich behaviors that include both event handlers and (un)transformations on DOM elements.
While CSS stylesheets let us apply styles to our HTML pages without worrying about DOM load, traversal or changes over the lifetime of a page, we have to define the behaviors of the elements in a totally different way:
/* the style sheet */
div.menu { display: block; }
div.menu li > a { color: blue; }
/* the behavior */
$('div.menu').do().something().with().element();
$('div.menu li > a').click(function (e) { ... });
The jQuery Behavior Plugin introduces a convention to define metabehaviors
that mimic the unobtrusive way of CSS stylesheets.
/* the style sheet */
div.menu { display: block; }
div.menu li > a { color: blue; }
/* the behavior */
$.behavior({
'div.menu li': {
'transform': function (e) { ... }
},
'div.menu li > a': {
'click': function (e) { ... }
}
});
In additon to the friendly syntax, the jQuery Behavior Plugin let us group and structure the actions into metabehaviors, it monitors DOM changes so that all behaviors are applied to future elements, and we can even definde behaviors for disappearing elements.
A metabehavior is the object describing the elements behaviors (before it is applied via the $.behavior function):
var metabehavior = {
'div.menu li': {
'transform': function (e) { ... }
},
'div.menu li > a': {
'click': function (e) { ... }
}
};
$.behavior(metabehavior);
The metabehavior object properties consists of jQuery CSS selectors and carry an object with jQuery events names and attached actions. All jQuery events are supported, even 'ajaxStart' and such. In addition to the jQuery events, two special events are defined: 'transform'
(a action that is applied if an element appears in DOM) and 'untransform'
(a action that is triggered when an element is removed from DOM).
The jQuery Behavior Plugin tries to evaluate <script>
tags with type="text/behavior"
. This makes it easy to inline (but difficult to debug) behaviors:
<script type="text/behavior">
input: {
transform: function () {
$(this).fadeOut(1000).fadeIn(1000);
}
}
</script>
This is experimental and disabled by default, to enable it use $.behavior.scriptTag = true
.
jQuery 1.7+
Live Query 1.1+
Example #1: http://jsfiddle.net/apy83/58/
Example #2: http://jsfiddle.net/ZUBVf/4/