UNPKG

todomvc

Version:

> Helping you select an MV\* framework

65 lines (54 loc) 1.76 kB
/*global NodeList */ (function (window) { 'use strict'; // Get element(s) by CSS selector: window.qs = function (selector, scope) { return (scope || document).querySelector(selector); }; window.qsa = function (selector, scope) { return (scope || document).querySelectorAll(selector); }; // addEventListener wrapper: window.$on = function (target, type, callback, useCapture) { target.addEventListener(type, callback, !!useCapture); }; // Register events on elements that may or may not exist yet: // $live('div a', 'click', function (event) {}); window.$live = (function () { var eventRegistry = {}; function dispatchEvent(event) { var targetElement = event.target; eventRegistry[event.type].forEach(function (entry) { var potentialElements = window.qsa(entry.selector); var hasMatch = Array.prototype.indexOf.call(potentialElements, targetElement) >= 0; if (hasMatch) { entry.handler.call(targetElement, event); } }); } return function (selector, event, handler) { if (!eventRegistry[event]) { eventRegistry[event] = []; window.$on(document.documentElement, event, dispatchEvent, true); } eventRegistry[event].push({ selector: selector, handler: handler }); }; }()); // Find the element's parent with the given tag name: // $parent(qs('a'), 'div'); window.$parent = function (element, tagName) { if (!element.parentNode) { return; } if (element.parentNode.tagName.toLowerCase() === tagName.toLowerCase()) { return element.parentNode; } return window.$parent(element.parentNode, tagName); }; // Allow for looping on nodes by chaining: // qsa('.foo').forEach(function () {}) NodeList.prototype.forEach = Array.prototype.forEach; })(window);