jQuery plugin that allows you to create a multi-page website with one HTML file.
xNav is not designed to be something you drag and drop into your project and it "just" works. This is because xNav is more than just an effect. Instead, xNav is a way to help you structure your code and make the user experience better by not forcing the browser to reload content that doesn't change throughout the site (like the navigation, footer, etc).
To implement xNav into your project, you need to have at least a <ul>
element to act as your menu, a containing <div>
, and a set of "content" <div>
's. See the code below:
<ul>
<li><a href="#container1">Container 1</a></li>
<li><a href="#container2">Container 2</a></li>
</ul>
<div id="content-pages">
<div class="content" id="container1">
<p>Content Container 1</p>
</div>
<div id="container2">
<p>Content Container 2</p>
</div>
</div>
After that include the xNav.js near your </body>
tag and set the configuration options in a new <script>
tag afterwards, like so:
<script>
$('#menu').xNav({
effect: 'fadeToggle',
contentContainer: $('#content-pages'),
defaultLink: 1,
navHelper: true,
animatedNavHelper: true,
isVertical: true
});
</script>
xNav probably shouldn't be used on most production sites right now, but feel free to use it if it fits the "one-file site" use case and you don't care about users that have JavaScript disabled. However, I'm still working on making this scalable across more than just "one file" sites.
So in short, it's great if you want to put up a small site with a small amount of data. Otherwise, you have the potential of making the user experience bad just because the client will be processing a lot of GET requests from that one file.
These are the options that you can pass to xNav as an option in the xNav.init function.
effect
: Any jQuery effect. The default is 'toggle'.
speed
: The speed of the effect in milliseconds. Undefined by default because jQuery sets it automatically.
menuItems
: A valid jQuery selector of your menu's list items. Defaults to list items that are children of a passed <ul>
element. Useful if you're storing your list items inside of a <div>
. Example: $('#menu-container #menu li')
contentContainer
: The valid jQuery selector of your data set's parent <div>
. Required.
navHelper
: Accepts true
or false
. This will turn on the navigation helper.
defaultLink
: The link to the data set that the navHelper with position itself with on load. Link numbers are not zero based.
animatedNavHelper
: Accepts true
or false
. This will animate the movements of the navHelper.
animatedNavHelperSpeed
: The speed of the navHelper's animation in milliseconds. Automatically set to 500
.
isVertical
: Accepts true
or false
. If you're using a vertical menu, this needs to be turned on.
useXHR
: Accepts true
or false
.
Using the useXHR configuration option allows you to create multiple HTML files and have xNav retrieve a specific part of them to load into the index.html page. The beauty of this is that if someone has JavaScript disabled your site will not break.
Here's how you set it up. Set up the menu and have the href
attribute point to the pages.
<ul id="menu">
<li><a href="index.html">Index</a></li>
<li><a href="contact.html">Contact</a></li>
<li><a href="about.html">About</a></li>
<li><a href="photos.html">Photos</a></li>
</ul>
Create your initial xNav data set inside of your contentContainer. This is where the content will be loaded. Put all the information for the home page in here.
<div class="content" id="xNavXHR">
<p>This is index.html</p>
</div>
Structure your other pages in the same way.
Anyone is welcome to contribute.