-
Notifications
You must be signed in to change notification settings - Fork 68
wire sizzle
The wire/sizzle
plugin provides integration with sizzle. It provides a reference resolver for querying DOM nodes that makes it easy to inject DOM nodes or lists of DOM nodes into your components. While the wire/dom plugin provides simple id-based DOM node injection, wire/sizzle
allows full DOM querying, basically anything supported by sizzle itself.
{
module: 'wire/sizzle'
// Easy! There are no options, just include the plugin.
}
The following is a reference to a list of DOM nodes with the class "my-class", using wire's standard JSON-reference-like syntax:
{ $ref: 'dom.query!.my-class' }
You can extract a single node by index from the query results. For example, the following is a reference to the first DOM node with the class "my-class"
{ $ref: 'dom.query!.my-class', i: 0 }
Here is an example of a wire spec that creates a simple view component (using the builtin create syntax, and supplies a DOM node to the view's constructor.
{
plugins: [
{
module: 'wire/sizzle'
}
],
// Create a view component, calling its constructor with a single arg,
// the first DOM Node returned by a query for nodes with the class
// 'myview-class'.
// Think of this as similar to
// new MyView(dojo.query('.myview-class')[0])
myView: {
create: {
module: 'my/View',
// Array of Constructor args. In this case, the DOM node
// as the only argument.
args: [{ $ref: 'dom.query!.myview-class', i: 0 }]
}
}
}