htmlcssscreenscreens

Cross-Screen support for navbar


I have created the nav bar for my page but it does not support multiple screens how can I make it support them?

HTM:

<section id="container">
    <section id="header">   <span id="icon">Icon</span>

        <input type="text" name="search_box" id="search_box">
        <nav id="dropdown_menu">
            <ul>
                <li>dropdown
                    <ul>
                        <li>Item 1</li>
                        <li>Item 2</li>
                    </ul>
                </li>
            </ul>
        </nav>
        <div class="vertical_bar" style="float: right; margin-right: 3%;"></div>
        <div id="notifications">    <span id="num_notifs">4</span>
L</div>
        <nav id="menu">
            <ul>
                <li>Home</li>
                <li>Office</li>
            </ul>
        </nav>  <span id="logo">Website Name</span>

    </section>
</section>

CSS:

#container {
    width: 100 % ;
    height: 100 % ;
    font-family: sans-serif !important;
}

#header {
    height: 5%;
    width: 100%;
    background-color: black;
    color: white;
}

#header span, div, input, nav {
    display: inline-block;
    vertical-align: middle;
    box-sizing: border-box;
    margin: 1%;
}

#header#search_box {
    margin: 0.5% 10%;
    background-image: url(../img/search_icon.png);
    background-repeat: no-repeat;
    background-size: 20px 20px;

}

#header#logo {
    float: right;
    margin-right: 7%;
    margin-top: 1%;
}

#header#menu {
    float: right;
    margin-right: 7%;
    margin-top: 1%;
}

#header#menu ul li {
    display: inline;
    margin: 5px;
}

#notifications {
    float: right;
    margin-right: 7%;
    margin - top: 0.5%;
    border: 2px solid white;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    font-weight: bold;
    text-align: center;
    padding: 2px;
    position: relative;
}

#notifications#num_notifs {
    font-size: small;
    position: absolute;
    top: 0;
    left: 80%;
    background-color: red;
    border-radius: 50%;
    width: 15px;
    height: 15px;
}

#header#dropdown_menu {
    float: right;
    margin-right: 2%;
    margin-top: 1%;
    text-align: center;
}

#header#dropdown_menu ul li: hover ul {
    display: block;
}

#header#dropdown_menu ul li ul {
    display: none;
}

#header#dropdown_menu ul li ul li: FIRST-CHILD {
    margin-top: 10px;
}

#header#dropdown_menu ul li ul li {
    margin-bottom: 10px;
}

Solution

  • By multiple screens, you mean screen resolutions/dimensions, right? Or are you referring to browsers? You are going to want to check out media queries, these are used to target different screen sizes..

    These are the media queries I use for my site, I followed the twitter bootstrap setup seen here:

    CSS

    /* Large desktop */
    @media (min-width: 1200px) { ... }
    
    /* Portrait tablet to landscape and desktop */
    @media (min-width: 768px) and (max-width: 979px) { ... }
    
    /* Landscape phone to portrait tablet */
    @media (max-width: 767px) { ... }
    
    /* Landscape phones and down */
    @media (max-width: 480px) { ... }
    

    Just place your CSS into each query, and you it should work well..

    Be sure to place this in your head though, this will eliminate problems with retina display:

    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    

    EDIT: Media queries are supported by all mobile devices, reference here.

    However, IE 6-8 do not support them.. a quick fix to this problem is to use the following below you stylesheet:

    <!--[if lt IE 9]><script src="http://css3-mediaqueries-js.googlecode.com/svn/trunk/css3-mediaqueries.js"></script><![endif]-->
    

    This is a poly-fill that will allow IE6-8 to use media queries..