Bootstrap Navbar Issue (Mobile)

Hi all,

Hoping you can help! I’ve been coding with Bootstrap and although the desktop edition works well (see image below) the mobile edition works, but refuses to show any of the links. From what I can see it should work, so I think I’m missing something stupid.

Any help is appreciated!

9dba08822a99abbaeb899ec59cda7eee03030181_2_690x287

EDIT - Code is as attached - HTML/Related CSS/Related JS

HTML

<div class="uc-mobile-menu uc-mobile-menu-effect">
    <button type="button" class="close" aria-hidden="true" data-toggle="offcanvas"
            id="uc-mobile-menu-close-btn">&times;</button>
    <div>
        <div>
            <ul id="menu">
                <li><a href="index.php">Home</a></li>
                <li><a href="index.php#about">About</a></li>
                <li><a href="tos.php">Terms of Service</a></li>
                <li><a href="product.php">Product A-Z</a></li>
                <li><a href="#contact">Contact</a></li>
                <li><a href="tel:+441384293222"><i class="fa fa-phone"></i> &nbsp;&nbsp;&nbsp; 01384 293 222</a></li>
                <li><a href="mailto:info@kiloltd.co.uk?subject=Website Enquiry"><i class="fa fa-envelope"></i> &nbsp;&nbsp;&nbsp; info@kiloltd.co.uk</a></li>
            </ul>
        </div>
    </div>
</div>

CSS

.uc-mobile-menu {
    }

.uc-mobile-menu-container > div {
    visibility : hidden;
    }

#menu {
    margin : 50px 40px;

    }

#menu > li {
    text-transform : uppercase;
    }

#menu > li:last-child {
    border-bottom : 0;
    }

#menu > li ul li {
    margin-left : 0;
    color       : #999999;

    }

#menu li a {
    display         : block;
    text-decoration : none;
    color           : #777777;
    padding         : 10px 0;
    font-size: 16px;
    border-bottom: 1px dotted #444;
    }


#menu li a:hover,
#menu li.active a {
    color : #ffffff;
    }

/*Mobile Menu Close*/
.uc-mobile-menu .close {
    position           : absolute;
    right              : 0;
    top                : 0;
    color              : #ffffff;
    text-shadow        : none;
    filter             : alpha(opacity=50);
    opacity            : .5;
    width              : 44px;
    height             : 44px;
    -webkit-transition : all 0.3s ease 0s;
    -moz-transition    : all 0.3s ease 0s;
    -o-transition      : all 0.3s ease 0s;
    transition         : all 0.3s ease 0s;
    }

.uc-mobile-menu .close:hover {
    opacity : 1;
    }

JS


;
(function ($) {
    $.fn.extend({
        ucOffCanvasMenu : function (options) {

            this.defaultOptions = {
                documentWrapper : '.wrapper',
                position        : 'left', // class name
                effect          : 'slide-on-top',         // class name
                contentWrapper  : '.contents',
                closeButton     : '.close',
                menuWrapper     : '.menu-wrapper',  // class name
                documentPusher  : '.pusher'
            };

            var isMobile = function () {
                var check = false;
                (function (a) {
                    if (/(android|ipad|playbook|silk|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i.test(a) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(a.substr(0, 4)))check = true
                })(navigator.userAgent || navigator.vendor || window.opera);
                return check;
            };

            var transitionEvent = function () {
                var t, el = document.createElement("fakeelement");

                var transitions = {
                    "transition"       : "transitionend",
                    "OTransition"      : "oTransitionEnd",
                    "MozTransition"    : "transitionend",
                    "WebkitTransition" : "webkitTransitionEnd"
                }

                for (t in transitions) {
                    if (el.style[t] !== undefined) {
                        return transitions[t];
                    }
                }
            };

            var animationEvent = function () {
                var t, el = document.createElement("fakeelement");

                var animations = {
                    "animation"       : "animationend",
                    "OAnimation"      : "oAnimationEnd",
                    "MozAnimation"    : "animationend",
                    "WebkitAnimation" : "webkitAnimationEnd"
                }

                for (t in animations) {
                    if (el.style[t] !== undefined) {
                        return animations[t];
                    }
                }
            };


            var settings = $.extend({}, this.defaultOptions, options);

            return this.each(function () {

                var $this = $(this);
                var eventType = isMobile() ? 'touchstart' : 'click';

                $(settings.documentWrapper)
                    .addClass('uc-offcanvas-wrapper')
                    .addClass(settings.position)
                    .addClass(settings.effect);

                //$(settings.menuWrapper).show();
                $(settings.menuWrapper).addClass('uc-offcanvas-init');
                $(settings.menuWrapper).addClass('uc-offcanvas-container');
                $(settings.documentPusher).addClass('uc-offcanvas-pusher');
                $(settings.contentWrapper).addClass('uc-offcanvas-contents');

                $(this).on(eventType, function (event) {

                    event.preventDefault();
                    event.stopPropagation();

                    $(this).addClass('uc-offcanvas-button-opened');
                    $(settings.menuWrapper).removeClass('uc-offcanvas-init');
                    $(settings.documentWrapper).addClass('uc-offcanvas-open');
                    $('html').addClass('uc-offcanvas-html-open');
                    $('body').addClass('uc-offcanvas-body-open');

                    $(window).trigger('uc-offcanvas-open', [settings, this]);

                });

                $(settings.closeButton).on(eventType, function (event) {

                    event.preventDefault();
                    event.stopPropagation();

                    $this.removeClass('uc-offcanvas-button-opened');
                    $(settings.documentWrapper).removeClass('uc-offcanvas-open');

                    $(window).trigger('uc-offcanvas-close', [settings, $this]);


                    setTimeout(function () {
                        $('html').removeClass('uc-offcanvas-html-open');
                        $('body').removeClass('uc-offcanvas-body-open');
                        $(window).trigger('uc-offcanvas-closed', [settings]);

                    }, 400);
  });

                $(document).on(eventType, function (event) {

                    if (!$(event.target).parents().hasClass('uc-offcanvas-container')) {

                        $this.removeClass('uc-offcanvas-button-opened');
                        $(settings.documentWrapper).removeClass('uc-offcanvas-open');

                        $(window).trigger('uc-offcanvas-close', [settings, $this]);

                        setTimeout(function () {
                            $('html').removeClass('uc-offcanvas-html-open');
                            $('body').removeClass('uc-offcanvas-body-open');
                            $(window).trigger('uc-offcanvas-closed', [settings]);

                        }, 400);

 }
                });
            });
        }
    });
})(jQuery);

If you click on the hamburger icon on the top right (the 3 lines), a drop down menu should appear. If not, be sure to double check if you have linked the relevant Java script and Jquery files to your html. Make sure all link correspond with the Boostrap version. Let me know if this helps.

Maybe you could share you html file here?

The menu appears on the double click, but none of the links associated with the list appear - its blank like in the image (I’ve just cut them from the localhost preview - bottom left is pre-click, bottom right is post-click)

I’ve also added the related HTML/JS/CSS coding if that helps :slight_smile:

Thanks again!

Cool, I see you only added the html relative to the navbar. Did you link the css in the head and Javascript and Jquery at the bottom of your body? I’ve had a similar issue and it was because I linked Javascript and Jquery to a different version of Bootstrap which I was using…

That I did - and both are linked to Bootstrap 3.3.6

Using linked URLs for the bootstrap CSS/JS - not sure whether that could be the cause then perhaps?

<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css"
          integrity="sha384-1q8mTJOASx8j1Au+a5WDVnPi2lkFfwwEAa8hDDdjZlpLegxhjVME1fgjWPGmkzs7" crossorigin="anonymous">

    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"
        integrity="sha384-0mSbJDEHialfmuBBQP6A4Qrprq5OVfW37PRR3j5ELqxss1yVqOtnepnHVP9aJ7xS"
        crossorigin="anonymous"></script>

Hmmm… I’m not too sure then. I am also quite new to this but thought maybe I could help. Hopefully someone else may be able to help you!

No worries - thanks for trying; your help is massively appreciated!! :smiley:

1 Like

@mylife42, welcome to the forums.
It looks like your missing the .data-target class and the matching id for the collapsible part. Check out this link to w3schools for additional help with collapsible navbars. (Of course you can Google and find lots more including Bootstraps own documentation.)

Hi Roma,

Thanks for that - I’ll add the .data-target and see if that helps :slight_smile: