Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bloqhead/mo-menu
A simple drop-in jQuery mobile menu solution.
https://github.com/bloqhead/mo-menu
Last synced: about 2 months ago
JSON representation
A simple drop-in jQuery mobile menu solution.
- Host: GitHub
- URL: https://github.com/bloqhead/mo-menu
- Owner: bloqhead
- Created: 2012-07-24T22:00:51.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2013-10-12T15:14:43.000Z (about 11 years ago)
- Last Synced: 2023-03-25T12:44:14.251Z (almost 2 years ago)
- Language: JavaScript
- Size: 176 KB
- Stars: 6
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: ReadMe.md
Awesome Lists containing this project
README
# Mo' Menu!
Short for 'Mobile Menu', this is a tiny jQuery plugin I built as a drop-in solution for adding a simple menu for responsive and mobile-based websites. It essentially clones your main navigation unordered list into the#mobileMenu
container and creates a mobile menu on the fly.## How to use it
If your navigation is within a container, you can specify the container as the selector, or you can specify the navigationul
itself. In your design, add the 'mobileMenu' container towards the top of your page. It will automatically appear as fixed to the top of the page, so container placement isn't as crucial.### The mobile menu container
This defaults to#mobileMenu
but you can define your own container id instead.```html
```### The jQuery
**Your nav container as the selector**```javascript
$('nav').moMenu();
```**or the navigation
ul
itself as the selector**```javascript
$('#menu').moMenu();
```**With optional parameters defined**
```javascript
$('#menu').moMenu({
nocontainer: true,
container: '#your-mobile-menu-container-id',
speed: 300,
theme: 'light'
});
```**NEW: Menu type parameter**
```javascript
$('#menu').moMenu({
type: 'slide',
nocontainer: true,
container: '#your-mobile-menu-container-id',
speed: 300,
theme: 'light'
});
```### The options
I've included some simple options for minimal customization. I also plan on adding color themes that can be defined as a parameter as well. Currently supported:* **nocontainer:** This defaults to false. If set to true, it will treat your navigation menu ul as the primary selector, as opposed to automatically grabbing the ul within a
nav
container or adiv
. Handy if your main navigation ul is not wrapped in anything.
* **container:** This defaults to#mobileMenu
but if you prefer to use a different id for the container that your mobile menu will be rendered in, you can specify it.
* **speed:** This is the speed of the slide up/down animation of the menu when the mobile menu button is clicked. It defaults to600
but you can define a custom speed in milliseconds.
* **auto:** If you don't want to manually add the#mobileMenu
div to your markup, setting theauto
option to true will automatically prepend the Mo Menu container to the body. This makes the plugin completely hands off.
* **theme:** There are currently 2 themes to pick from: the default (black) one and a 'light' generic style. If you decide to roll your own theme, you can define its class in thetheme
attribute and the plugin will render the class as.moMenu-yourclassname
.
* **zindex:** Now you can set thez-index
of the menu.
* **animation:** There are 2 choices for the animation style:toggle
andslideToggle
. The menu automatically defaults toslideToggle
but if you would prefer the menu to appear immediately without animation,toggle
will make it happen.
* **type:** This is a big one. Want a mobile menu that slides out from the left instead of down from the top? Now it's possible. Simply addtype: 'slide'
to your moMenu call and you're done. [View the demo video](http://f.cl.ly/items/0X3D1L041P120h0q353e/Screeny%20Video%20Oct%2024,%202012%2012.46.02%20PM.mov)The Mo' Menu script will do the rest. It will copy your main navigation into the mobileMenu container, format it all nicely and be completely accessible for mobile users.
#### Beta Functionality
##### Browser Dimensions Detection using resize();
I've set the menu up to automatically detect browser width on the fly via the jQueryresize()
function but haven't tested this in the wild yet. It works properly in my demo but mileage may vary for other applications. This functionality will detect browser window width and set the top-padding of the body to either the default (40px) value or to the value that you explicitly set via thepadding
option mentioned above in the options section. When the browser is resized to something other than assumed mobile width, it will reset the top-padding of the body tag to whatever was originally applied to it (if anything). The method to accomplish this is somewhat primitive but it works. I'm sure it could be written better.##### Menu Type
This is still a beta feature and has not been thoroughly tested. If you encounter any issues, please let me know or tinker with my code and submit a bug fix. I love feedback. The code will still work perfectly without thetype
variable defined.### License
© 2012, Daryn St. Pierre — [bloqhead.com](http://bloqhead.com/)Released under the [WTFPL License](http://sam.zoy.org/wtfpl/).