In most of the cases we rely on DOM events. They are tightly bound to our workflow. We normally add elements to the DOM tree dynamically. Whenever we want to get info from them we have to add event listeners. And guess what? Most of us are doing this every time when the UI is changed. That's because we remove or replace node's content. In such cases the attached listeners are gone. Bubble.js aims to help here. It adds listeners to the root of our logical blocks. It uses the bubbling model and nicely catches elements' events.
Include Bubble.js in your page.
<script src="js/bubble.min.js"></script>
Pick the area where Bubble.js will operate and set a proper data-bubble-action
describing your events. For example:
<div class="header">
<a href="#" data-bubble-action="click:logo">logo</a>
<input type="text" name="filter" data-bubble-action="keyup:filter, blur:filter-leaved" />
<ul>
<li><a href="#" data-bubble-action="click:about">About</a></li>
<li><a href="#" data-bubble-action="click:contacts">Contacts</a></li>
</ul>
</div>
After that initialize the bubble:
// use a selector to element
// that wraps your dispatchers
var b = bubble('.header');
And define the handlers of your events:
b.on('logo', function(e) { console.log('Logo link clicked!'); })
.on('about', function(e) { console.log('About link clicked!'); })
.on('contacts', function(e) { console.log('Contacts link clicked!'); })
.on('filter', function(e) { console.log('Filter: ' + e.target.value); })
.on('filter-leaved', function() { console.log('Filter field leaved'); });
or
b.on({
logo: function(e) { console.log('Logo link clicked!'); },
about: function(e) { console.log('About link clicked!'); },
contacts: function(e) { console.log('Contacts link clicked!'); },
filter: function(e) { console.log('Filter: ' + e.target.value); },
'filter-leaved': function(e) { console.log('Filter field leaved'); }
});
Check out the result here.
npm install
npm run build
Open tests
directory in a browser or click on this link.