Application
The Application class serves as the main entry point for a Viking.js application. It handles routing, layout management, and content display.
Constructor
new Application(options)
options
:
Object
Instance Properties
Internal storage for DOM event listeners
Properties from the options object that will be assigned directly to the view instance
HTML attributes to set on the view's element
Object containing references to objects this instance is listening to
The CSS class name(s) to set on the view's element
Default property values for the view
The DOM element for the view, can be a CSS selector, HTML element, or function returning either
Object containing all event listeners
Default event bindings for the application
Define properties to be included when calling layout or display a template
The ID attribute to set on the view's element
Define a layout function to wrap the view content, is called everytime layout changes
Parameters
locals
:
Object
Properties of the view with a property called "content" assigned as the displayed template
Returns
Elements
|
Boolean
Elements to append, return false to not render layout
Unique identifier for this event bus instance
Properties that should be copied from the static class to the instance
An array for storing subViews attached to this view
The HTML tag name to use when creating the view's element
Template for the view
The default title for the application
Instance Methods
Removes the view's element from the DOM
Finds an element within the view's element using a CSS selector
Parameters
selector
:
string
CSS selector to search for
Returns
Element
|
null
The first matching element or null if not found
Bind an event to a callback function. Passing "*" will bind
the callback to all events fired.
If the options.once is true, the event will only be triggered a single time. After the first time the callback is invoked, its listener will be removed. If multiple events are passed in as an array, the handler will fire once for each event, not once for a combination of all events.
Parameters
name
:
string
|
Array.<string>
|
object
Event name(s) or object of event/callback pairs
callback
:
function
|
object
Callback function or options object if name is an object
options
:
object
optionalEvent options
once
:
boolean
optionalWhether the event should only trigger once
context
:
object
optionalThe context to bind the event to
listener
:
object
optionalThe listener object
Returns
EventBus
Returns this for chaining
Tell this object to listen to an event in another object, while keeping track of what it's listening to for easier unbinding later.
Parameters
obj
:
object
|
NodeList
The object to listen to events on
name
:
string
|
Array.<string>
|
object
Event name(s) or object of event/callback pairs
callback
:
function
|
object
Callback function or options object if name is an object
options
:
object
optionalEvent options
once
:
boolean
optionalWhether the event should only trigger once
context
:
object
optionalThe context to bind the event to
Returns
EventBus
Returns this for chaining
Set up event delegation for the view
This method binds event handlers defined in the events hash to the view's element.
The events hash format is: {'event selector': handler}
Callbacks will be bound to the view with this set properly.
Omitting the selector binds the event to the view's element itself.
Parameters
Returns
View
The view instance for chaining
Examples
{
'mousedown .title': 'edit',
'click .button': 'save',
'click .open': function(e) { ... },
'click .title': ['edit', false],
'click .title': ['edit', {passive: true}]
}Trigger one or many events, firing all bound callbacks. Callbacks are
passed the same arguments as dispatchEvent is, apart from the event name
(unless you're listening on "*", which will cause your callback to
receive the true name of the event as the first argument).
Parameters
name
:
string
|
Array.<string>
Event name or array of event names
args
:
*
Arguments to pass to the event handlers
Returns
EventBus
Returns this for chaining
Display content
Parameters
template
:
function
Function returning element(s), receives merger of locals and helpers as arugment
Returns
null
Examples
this.display(userShow, {user: user}, {layout: false})Called after the DOM element is created Override this method to perform initialization after the view's element is set up
Event handler for link clicks that uses pushState for navigation when possible Allows the application to handle internal navigation without page reloads
Parameters
e
:
Event
The click event
Removes this view and all subviews from the DOM
This method removes the view's element from the DOM, cleans up any event listeners, and recursively removes all subviews.
Returns
View
The view instance for chaining
Remove one or many callbacks that match the arguments. If called with no arguments, removes all callbacks for all events.
Parameters
name
:
string
|
Array.<string>
|
object
|
null
optionalEvent name(s) or object of event/callback pairs
callback
:
function
|
object
|
null
optionalCallback function or options object if name is an object
options
:
object
optionalEvent options
once
:
boolean
optionalMatch only events set to trigger once
context
:
object
optionalMatch only events bound to this context
listener
:
object
optionalMatch only events bound by this listener
Returns
EventBus
Returns this for chaining
Tell this object to stop listening to either specific events or to every object it's currently listening to.
Parameters
obj
:
object
|
NodeList
optionalThe object to stop listening to; if omitted, stops listening to all objects
name
:
string
|
Array.<string>
|
object
optionalEvent name(s) or object of event/callback pairs
callback
:
function
optionalCallback function to remove
options
:
object
optionalEvent options
once
:
boolean
optionalMatch only events set to trigger once
context
:
object
optionalMatch only events bound to this context
Returns
EventBus
Returns this for chaining
Removes a subview from this view
This method removes the subview by calling its remove method, which will ultimately trigger the afterRemove event, causing it to be removed from the subViews array.
Parameters
Renders the view's content
This is the core function that your view should override to populate its element
with the appropriate HTML. The convention is for render to always return this
to enable method chaining.
Returns
View
The view instance for chaining
Change the view's element and re-delegate events
This method changes the view's element (this.el property) and
re-delegates the view's events on the new element.
Parameters
element
:
Element
|
NodeList
|
string
The new element, can be a CSS selector, Element node, or NodeList (the first item will be used)
Returns
Element
The new element
setup()
Sets up the application by initializing the router and running initializers Called automatically during construction
Starts the application and its router if one exists
Returns
Application
Returns the application instance for chaining
Creates a subview and adds it to this view's subviews array
Parameters
args
:
*
Arguments to pass to the subview constructor
Returns
View
The created subview instance
Handler for a subview's afterRemove event
Parameters
Remove all event listeners from the view's element
This method clears all callbacks previously bound to the view by delegateEvents. It's automatically called when changing elements or removing the view.
Returns
View
The view instance for chaining
