Created
June 26, 2014 12:43
-
-
Save connormckelvey/8691c5b8a68a8ae02fe7 to your computer and use it in GitHub Desktop.
DOM Base Routing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* ======================================================================== | |
* DOM-based Routing | |
* Based on http://goo.gl/EUTi53 by Paul Irish | |
* | |
* Only fires on body classes that match. If a body class contains a dash, | |
* replace the dash with an underscore when adding it to the object below. | |
* | |
* .noConflict() | |
* The routing is enclosed within an anonymous function so that you can | |
* always reference jQuery with $, even when in .noConflict() mode. | |
* | |
* Google CDN, Latest jQuery | |
* To use the default WordPress version of jQuery, go to lib/config.php and | |
* remove or comment out: add_theme_support('jquery-cdn'); | |
* ======================================================================== */ | |
(function($) { | |
// Use this variable to set up the common and page specific functions. If you | |
// rename this variable, you will also need to rename the namespace below. | |
var SiteName = { | |
// All pages | |
common: { | |
init: function() { | |
} | |
}, | |
// Home page | |
home: { | |
init: function() { | |
} | |
} | |
}; | |
// The routing fires all common scripts, followed by the page specific scripts. | |
// Add additional events for more control over timing e.g. a finalize event | |
var UTIL = { | |
fire: function(func, funcname, args) { | |
var namespace = SiteName; | |
funcname = (funcname === undefined) ? 'init' : funcname; | |
if (func !== '' && namespace[func] && typeof namespace[func][funcname] === 'function') { | |
namespace[func][funcname](args); | |
} | |
}, | |
loadEvents: function() { | |
UTIL.fire('common'); | |
$.each(document.body.className.replace(/-/g, '_').split(/\s+/),function(i,classnm) { | |
UTIL.fire(classnm); | |
}); | |
} | |
}; | |
$(document).ready(UTIL.loadEvents); | |
})(jQuery); // Fully reference jQuery after this point. | |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment