Juggler is a simple tool that allows to move (not copy!) the element nodes from one place to another in the DOM when they match the provided media query.
During the design implementation it can happen that some elements must be moved around as not everything can be achieved with pure CSS. Consider the following HTML structure:
<div class="header">
<div class="logo">...</div>
<div class="navigation">...</div>
<div class="mobile-box-trigger">...</div>
<div class="mobile-box">
<!-- we want to display .navigation here but only on mobile -->
</div>
</div>
What if you had to move the .navigation
div into the .mobile-box
but only on the small devices?
That's where the Juggle.js comes in handy and solves the problem with ease:
<div class="header">
<div class="logo">...</div>
<div class="navigation" data-juggler-source="navigation">...</div>
<div class="mobile-box-trigger">...</div>
<div class="mobile-box">
<!-- the .navigation will be displayed here on mobile -->
<div data-juggler-target="navigation" data-juggler-media-query="(max-width: 767px)"></div>
</div>
</div>
When the document is ready (e.g. DOMContentLoaded
event is triggered) the script gathers all Juggler elements
and puts them in an internal registry. To preserve the location of the source and target elements for further
reference the HTML comments are added before the source element and as a replacement of the target element.
This way the temporary placeholders do not interfere with other elements and do not break CSS nor JS.
Download the package and include the file on your page:
<script src="assets/js/juggler.min.js"></script>
Then intiialize the script once DOM is ready:
document.addEventListener('DOMContentLoaded', Juggler.init());
// or
document.addEventListener('DOMContentLoaded', function () {
Juggler.init();
});
There are basically two things you have to configure:
- Source element
The original element you would like to juggle. It must have a unique ID specified the attribute:
<div data-juggler-source="my_unique_id">...</div>
- Target element
The element that will be replaced by the source element when necessary. It must refer to the existing source element and contain a valid CSS media query:
<div data-juggler-target="my_unique_id" data-juggler-media-query="(max-width: 767px)"></div>
You can also use the boolean flags instead of media queries, see the demo files for example.
<div data-juggler-source="my_unique_id">...</div>
<div data-juggler-target="my_unique_id" data-juggler-flag="foobar"></div>
<script>
Juggler.setFlag('foobar', true);
Juggler.setFlag('foobar', false);
</script>
- When you clone an element that is a Juggler source, make sure to remove the data attribute or you will get an error of duplicate source items.
This project has been created and is maintained by Codefog.