Data Ajax
Purpose
A basic AjaxLoader wrapper that inserts AJAXed-in content.
Executing WET plugin on AJAXed-in content
/**
* @title Execute any WET plugin on AJAXed-in content
* @license wet-boew.github.io/wet-boew/License-en.html / wet-boew.github.io/wet-boew/Licence-fr.html
* @author @duboisp (Github)
* @version 1.0.0+2016-10-14
*/
(function( $, document, wb ) {
"use strict";
$('#mycontainer').on( "wb-contentupdated", function( event, data ){
// "data.ajax-type" contains the insersion method [after, append, before, prepend, replace]
// "data.content" contains the
var $elm = $(event.currentTarget);
$elm
.find( wb.allSelectors )
.addClass( "wb-init" )
.filter( ":not(#" + $elm.attr( "id" ) + " .wb-init .wb-init)" )
.trigger( "timerpoke.wb" );
/*
* Since we are working with events we want to ensure that we are being
* passive about our control, so returning true allows for events to always
* continue
*/
return true;
});
})( jQuery, document, wb );
Be careful to not execute it on every data-ajax container to avoid a possible recursive self calling situation.
Working example
How to implement
-
Add one of the following data-ajax attributes to an element, with the attribute value being the URL of the content to AJAX in:
-
data-ajax-after
: Insert content after the element<section data-ajax-after="ajax/data-ajax-extra-en.html"> ... </section>
-
data-ajax-append
: Insert content at the end of the element<section data-ajax-append="ajax/data-ajax-extra-en.html"> ... </section>
-
data-ajax-before
: Insert content before the element<section data-ajax-before="ajax/data-ajax-extra-en.html"> ... </section>
-
data-ajax-before
: Insert content at the start of the element<section data-ajax-prepend="ajax/data-ajax-extra-en.html"> ... </section>
-
data-ajax-before
: Replace the element with the content<section data-ajax-replace="ajax/data-ajax-extra-en.html"> ... </section>
-
- Optional (v4.0.12+): Filter the content using the URL hash (
ajax/data-ajax-filter-en.html#filter-id
) or a selector (ajax/data-ajax-filter-en.html .filter-selector
).
Configuration options
Option | Description | How to configure | Values |
---|---|---|---|
Overlay type | Configure the origin and destination of the content to AJAX in. | Add the configuration attribute to the affected element with the value being the URL of the content to AJAX in. |
|
Events
Event | Trigger | What it does |
---|---|---|
wb-init.wb-data-ajax |
Triggered manually (e.g., $( "[data-ajax-after], [data-ajax-append], [data-ajax-before], [data-ajax-prepend], [data-ajax-replace]" ).trigger( "wb-init.wb-data-ajax" ); ). |
Used to manually initialize the Data Ajax plugin. Note: The Data Ajax plugin will be initialized automatically unless the required markup is added after the page has already loaded. |
wb-ready.wb-data-ajax (v4.0.5+) |
Triggered automatically after the content has been AJAXed in. | Used to identify where content has been AJAXed in by the plugin (target of the event) and to pass along how the content was included ("after", "append", "before", "prepend" or "replace").
|
wb-ready.wb (v4.0.5+) |
Triggered automatically when WET has finished loading and executing. | Used to identify when all WET plugins and polyfills have finished loading and executing.
|
wb-contentupdated |
Triggered automatically when data-ajax has finished to load the response. | Use to perform a secondary action upon ajax content is loaded
|
Source code
- Date modified: