SlideShare a Scribd company logo
1 of 53
Download to read offline
What? Why? How?

  What is responsive web design?

  How to create a responsive layout

  How to ensure all site elements work
  in that layout
  Setting breakpoint changes with
  Media Queries
  Responsive menu options
What is A Responsive WebSITE?


A fluid layout and flexible images adapted
with media queries
Responsive            vs.   Adaptive

A fluid grid layout         Multiple fixed width
                            layouts

Additional changes          Layout changes at
applied with Media          set breakpoints
Queries                     (with Media Queries)
Basic Components

  A flexible, grid-based layout

  Flexible images and media

  Media queries for specific adjustments
Hybrid Approaches

Fluid on smaller screens
+ fixed maximum size

One column flexible
+ one column fixed
Let’s Get Started!
   AmeliaMarschall.com
Set a fluid grid

Fluid wrapper:
 #page { !

    width: 90%;!

    max-width: 960px; !

    margin: 15px auto; }!
or
 #page { 

    width: 960px; 

    max-width: 90%;

    margin: 15px auto; }!
Set a fluid grid

Float columns:
 !

 #LeftColumn {

    float: left;

    width: 70%; }!
 !

 #RightColumn {

    float: right;

    width: 30%; }!
Set Fixed Margins (really, It’s Ok!)

Use CSS Box Sizing

Standard box model:   New box model:

Padding & border      Padding & border
added on to width/    subtracted from
height                width/height

box-sizing:           box-sizing:
content-box!          border-box!
Set Fixed Margins (Actually padding)

#LeftColumn {

    padding: 10px 20px; 

                      !
    -moz-box-sizing:border-box;

    -webkit-box-sizing:border-box;!

    box-sizing:border-box; }!


#RightColumn {

    padding: 10px;
                 !

    -moz-box-sizing:border-box;

    -webkit-box-sizing:border-box;!

    box-sizing:border-box;

    border: 1px solid #627A7E; }!

IE Polyfill: (Natively supported in IE8+)
https://github.com/Schepp/box-sizing-polyfill
Nested Columns

Widths set with percentage are relative to
their container element!
Nested Columns

#dnn_ContentLeft {

  float: left;

   width: 60%;

   padding-right: 40px;

   box-sizing: border-box; }!


#dnn_ContentRight {

   float: left;

   width: 40%;

   box-sizing: border-box; }!
Make Changes with Media Queries


Media queries serve different CSS based
on your browser size or type
Include directly in your CSS file, at the end:
@media (max-width: 900px) { }!
!

Or link separate CSS files from your HTML:
<link rel=“stylesheet” type=“text/
css” href=“style.css” media=“all
and (min-width: 481px)”>!
Make Changes with Media Queries


Define regular (desktop site) styles, then:
•  @media (max-width: 900px) { }!
•  @media (max-width: 720px) { }!
•  @media (max-width: 480px) { }!
•  @media (max-width: 320px) { }!
Make Changes with Media Queries

Or, go “mobile first”:
•  @media (min-width: 480px) {   }!
•  @media (min-width: 720px) {   }!
•  Etc…!

Better for performance!
Make Changes with Media Queries
Media Queries & IE
@media only works in IE 9 +
•  Javascript polyfill for IE 8 and below:
  –  https://github.com/scottjehl/Respond
  –  Adds support for media queries set with
     min-width/max-width

•  For wider media query support:
  –  http://code.google.com/p/css3-mediaqueries-js

•  Or use conditional comments to link to IE CSS
Example Site Queries

@media (max-width: 900px) {
 !#ContentLeft, #ContentRight {!   

 ! ! width:100%; !

                !
      padding:0; !
 !}

}!
@media (max-width: 900px)!
Example Site Queries
@media (max-width: 730px) { 

   #LeftColumn, #RightColumn { ! !
 !     width: 100%;! !

   !}



   #FooterLeft, #FooterMiddle,   !
 ! #FooterRight {! !

       width: 100%; ! !

       margin: 0 0 20px 0; !
 ! !}

}!
Example Site Queries

@media (max-width: 650px) {

   #primary .show-mobile {! !

 !    display: block; ! !

      padding: 20px 20px 20px 64px;
 ! ! background: url(images/mobile-
 ! ! menu.png) no-repeat #8CC8D8;!
                                 !
 ! }

}!
Example Site Queries
@media (max-width: 470px) {     

 !#page {! !

      width:96%; ! !

      margin:5px auto; } !
 !#branding hgroup { !

      width: 100%; } ! !

   #primary {! !

      margin: 0 0 10px 0;! !

      width:100%; }

   #primary .show-mobile { ! !

      width:100%;!}

}!
Set Font Sizes

Set font sizes in em’s:
•  body { font-size: 100%; } 

   ( 16px )
•  h1 { font-size: 1.5 em } 

   ( 24px / 16px = 1.5 )
•  Change body size in @media to adjust all
   site fonts
Use Fittext.js for scalable headlines that fit
the width of its surrounding element.
Set (or don’t set) Media Sizes

Ensure media always stays within set columns:
•  img, object, embed, iframe, video
   { max-width:100%; }

 !


•  Do not set inline height and width of
   images or media
•  Use Fitvidsjs.com for video (unless actually
   using the <video> element)
Load Specifically-sized images

Use mobile-first media queries to only load
larger images once needed

Or use Adaptive Images: adaptive-images.com
•  Detects screen size.
•  Automatically creates, caches, and delivers re-scaled
   versions of embedded HTML images.
•  No mark-up changes needed.
•  Original PHP by Matt Wilcox. Ports for .NET and Cold
   Fusion, Plugins for Wordpress and Drupal.
Hide Content

display:none!
•  Hide unnecessary content for mobile
•  Add mobile only content with
   display:none in the regular CSS

Important Note:
With no “link to full site”, don’t hide too much!
Hide Content

EXTRA Important Note:
display:none hides content but
(generally) does not improve performance!

Hiding images:
Setting parent element to display:none
will prevent the image from being loaded.
Responsive Menu Options

Use unordered list menu layouts:
<nav> 

  <ul> 

    <li><a   href="/”>Home</a></li> 

    <li><a   href="/About.aspx">About</a></li> 

    <li><a   href="/Speaking.aspx">Speaking</a></li> 

    <li><a   href="/Contact.aspx">Contact</a></li> 

  </ul> 

</nav>!
1. Flow the menu onto two lines
1. Flow the menu onto two lines


What a horizontal unordered list will
naturally do

Can hide submenu dropdowns (If
accessible elsewhere)
•  nav ul li ul { display:none; }!

Use media queries to reduce font sizes
before breaking to two lines
1. Flow the menu onto two lines

Tutorial: http://designshack.net/articles/css/
code-a-responsive-navigation-menu
1. Flow the menu onto two lines

When to use it?
   Submenus don’t need to be accessed

   Items will fit on two lines

   Items not expected to change often

   A solution without Javascript is desired

   Minimal effort desired
2. Switch a horizontal menu to vertical
2. Switch a horizontal menu to vertical


Regular CSS:
•  nav ul li { float:left; }!
Mobile-size CSS:
•  @media (max-width: 480px) { 

     nav ul li { float:none; ! !
  !     width:100%; }!
    }!
Can hide submenu dropdowns (If accessible
elsewhere)
•  nav ul li ul { display:none; }!
2. Switch a horizontal menu to vertical


Tutorial to include dropdown submenus:
http://ejhansel.com/a-responsive-drop-down-navigation-menu
•  Based on Suckerfish dropdowns
•  Uses :hover to expand submenus
2. Switch a horizontal menu to vertical


When to use it?

    More menu items

    Longer page names

    Can choose whether to include submenus

    A solution without Javascript is desired

    Minimal effort desired
3. Switch to an expandable menu button
3. Switch to an expandable menu button


Similar to switching a horizontal menu
to vertical, with the addition of hiding
the menu until clicked/touched

The markup:
<nav> ! !

    !
   <a href="#" class=”

    show-mobile">Main Menu</a>             !   

   <ul><li>…</li></ul> !

</nav>!
3. Switch to an expandable menu button


•  Regular CSS:
    .show-mobile { display: none; }!
•  CSS to show the button and hide the menu for mobile:
    @media (max-width: 768px) { ! !

       nav .show-mobile {

         display: block; }

       nav ul {  !

         display: none; }          }!
•  jQuery for the menu toggle:
     <script> ! !

       jQuery(".show-mobile").click(function () { 

         jQuery("nav ul").toggle("fast"); !

       });

    <script>
3. Switch to an expandable menu button


An in-depth, mobile-first menu tutorial:
•  http://azadcreative.com/2012/07/
   responsive-mobile-first-navigation-menu
•  Uses a mobile menu button toggle, and
   includes submenus expanding on click/
   touch
3. Switch to an expandable menu button


When to use it?

    Want mobile menu to fit in a small area

    Want a highly stylable, flexible option

    More menu items and/or longer page names

    Can choose whether to include submenus

    Ok with an “extra click” before selecting
4. Switch to a dropdown (select) menu
4. Switch to a dropdown (select) menu


Uses efficient native mobile controls
Use jQuery to dynamically swap:
<nav>

   <ul> 

     <li><a href=“#”>…</a></li> 

   </ul>

</nav>

-to-
<nav>

   <select> 

     <option value=“#”>…</option>

   </select>

</nav>!
From: http://css-tricks.com/convert-menu-to-dropdown
!
4. Switch to a dropdown (select) menu


Similar options that switch <ul> to <select>:
•  TinyNav.js:
  –  Uses jQuery, small file size
  –  https://github.com/viljamis/TinyNav.js
•  Responsive Menu:
  –  Uses jQuery, supports submenus, lots of settings
  –  https://github.com/mattkersley/Responsive-Menu
•  SelectNav.js:
  –  Inspired by TinyNav, Independent (no jQuery),
     supports submenus
  –  http://lukaszfiszer.github.com/selectnav.js
4. Switch to a dropdown (select) menu


When to use it?

    Want mobile menu to fit in a small area

    Want native controls for the mobile menu

    More menu items and/or longer page names

    Want submenus included

    Ok with an “extra click” before selecting
Remember the Viewport

Ensure mobile browsers will scale to view
your site correctly

Include in the <head> :
  <meta name="viewport"
  content="width=device-width”>!
Resources

•  Responsive Web Design (A Book Apart 4)
   Ethan Marcotte
•  MediaQueri.es
•  http://bradfrostweb.com/responsive-web-
   design-newsletter
•  http://zomigi.com/blog/essential-
   considerations-for-crafting-quality-media-
   queries
!
Questions?
Amelia Marschall-Miller
Gravity Works Design + Development
Partner & Creative Director

GravityWorksDesign.com
AmeliaMarschall.com
      @MimiAmelia

More Related Content

Featured

2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by HubspotMarius Sescu
 
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTEverything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTExpeed Software
 
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsProduct Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsPixeldarts
 
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthThinkNow
 
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfAI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfmarketingartwork
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024Neil Kimberley
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)contently
 
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024Albert Qian
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsKurio // The Social Media Age(ncy)
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Search Engine Journal
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summarySpeakerHub
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd Clark Boyd
 
Getting into the tech field. what next
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next Tessa Mero
 
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentLily Ray
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best PracticesVit Horky
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project managementMindGenius
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...RachelPearson36
 

Featured (20)

2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot
 
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTEverything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPT
 
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsProduct Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage Engineerings
 
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
 
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfAI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
 
Skeleton Culture Code
Skeleton Culture CodeSkeleton Culture Code
Skeleton Culture Code
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
 
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
 
Getting into the tech field. what next
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next
 
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
 
How to have difficult conversations
How to have difficult conversations How to have difficult conversations
How to have difficult conversations
 
Introduction to Data Science
Introduction to Data ScienceIntroduction to Data Science
Introduction to Data Science
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best Practices
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project management
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
 

Responsive Web Design: From Mobile To Desktop, And Beyond

  • 1.
  • 2. What? Why? How? What is responsive web design? How to create a responsive layout How to ensure all site elements work in that layout Setting breakpoint changes with Media Queries Responsive menu options
  • 3. What is A Responsive WebSITE? A fluid layout and flexible images adapted with media queries
  • 4. Responsive vs. Adaptive A fluid grid layout Multiple fixed width layouts Additional changes Layout changes at applied with Media set breakpoints Queries (with Media Queries)
  • 5. Basic Components A flexible, grid-based layout Flexible images and media Media queries for specific adjustments
  • 6. Hybrid Approaches Fluid on smaller screens + fixed maximum size One column flexible + one column fixed
  • 7. Let’s Get Started! AmeliaMarschall.com
  • 8. Set a fluid grid Fluid wrapper: #page { !
 width: 90%;!
 max-width: 960px; !
 margin: 15px auto; }! or #page { 
 width: 960px; 
 max-width: 90%;
 margin: 15px auto; }!
  • 9. Set a fluid grid Float columns: ! #LeftColumn {
 float: left;
 width: 70%; }! ! #RightColumn {
 float: right;
 width: 30%; }!
  • 10. Set Fixed Margins (really, It’s Ok!) Use CSS Box Sizing Standard box model: New box model: Padding & border Padding & border added on to width/ subtracted from height width/height box-sizing: box-sizing: content-box! border-box!
  • 11. Set Fixed Margins (Actually padding) #LeftColumn {
 padding: 10px 20px; 
 ! -moz-box-sizing:border-box;
 -webkit-box-sizing:border-box;!
 box-sizing:border-box; }! 
 #RightColumn {
 padding: 10px; !
 -moz-box-sizing:border-box;
 -webkit-box-sizing:border-box;!
 box-sizing:border-box;
 border: 1px solid #627A7E; }! IE Polyfill: (Natively supported in IE8+) https://github.com/Schepp/box-sizing-polyfill
  • 12. Nested Columns Widths set with percentage are relative to their container element!
  • 13. Nested Columns #dnn_ContentLeft {
   float: left;
 width: 60%;
 padding-right: 40px;
 box-sizing: border-box; }! 
 #dnn_ContentRight {
    float: left;
 width: 40%;
 box-sizing: border-box; }!
  • 14. Make Changes with Media Queries Media queries serve different CSS based on your browser size or type Include directly in your CSS file, at the end: @media (max-width: 900px) { }! ! Or link separate CSS files from your HTML: <link rel=“stylesheet” type=“text/ css” href=“style.css” media=“all and (min-width: 481px)”>!
  • 15. Make Changes with Media Queries Define regular (desktop site) styles, then: •  @media (max-width: 900px) { }! •  @media (max-width: 720px) { }! •  @media (max-width: 480px) { }! •  @media (max-width: 320px) { }!
  • 16. Make Changes with Media Queries Or, go “mobile first”: •  @media (min-width: 480px) { }! •  @media (min-width: 720px) { }! •  Etc…! Better for performance!
  • 17. Make Changes with Media Queries
  • 18. Media Queries & IE @media only works in IE 9 + •  Javascript polyfill for IE 8 and below: –  https://github.com/scottjehl/Respond –  Adds support for media queries set with min-width/max-width •  For wider media query support: –  http://code.google.com/p/css3-mediaqueries-js •  Or use conditional comments to link to IE CSS
  • 19. Example Site Queries @media (max-width: 900px) { !#ContentLeft, #ContentRight {! 
 ! ! width:100%; !
 ! padding:0; ! !}
 }!
  • 21. Example Site Queries @media (max-width: 730px) { 
 #LeftColumn, #RightColumn { ! ! ! width: 100%;! !
 !}
 
 #FooterLeft, #FooterMiddle, ! ! #FooterRight {! !
 width: 100%; ! !
 margin: 0 0 20px 0; ! ! !}
 }!
  • 22.
  • 23. Example Site Queries @media (max-width: 650px) {
 #primary .show-mobile {! !
 ! display: block; ! !
 padding: 20px 20px 20px 64px; ! ! background: url(images/mobile- ! ! menu.png) no-repeat #8CC8D8;! ! ! }
 }!
  • 24.
  • 25. Example Site Queries @media (max-width: 470px) { 
 !#page {! !
 width:96%; ! !
 margin:5px auto; } ! !#branding hgroup { !
 width: 100%; } ! !
 #primary {! !
 margin: 0 0 10px 0;! !
 width:100%; }
 #primary .show-mobile { ! !
 width:100%;!}
 }!
  • 26.
  • 27. Set Font Sizes Set font sizes in em’s: •  body { font-size: 100%; } 
 ( 16px ) •  h1 { font-size: 1.5 em } 
 ( 24px / 16px = 1.5 ) •  Change body size in @media to adjust all site fonts Use Fittext.js for scalable headlines that fit the width of its surrounding element.
  • 28. Set (or don’t set) Media Sizes Ensure media always stays within set columns: •  img, object, embed, iframe, video { max-width:100%; }
 ! •  Do not set inline height and width of images or media •  Use Fitvidsjs.com for video (unless actually using the <video> element)
  • 29. Load Specifically-sized images Use mobile-first media queries to only load larger images once needed Or use Adaptive Images: adaptive-images.com •  Detects screen size. •  Automatically creates, caches, and delivers re-scaled versions of embedded HTML images. •  No mark-up changes needed. •  Original PHP by Matt Wilcox. Ports for .NET and Cold Fusion, Plugins for Wordpress and Drupal.
  • 30. Hide Content display:none! •  Hide unnecessary content for mobile •  Add mobile only content with display:none in the regular CSS Important Note: With no “link to full site”, don’t hide too much!
  • 31. Hide Content EXTRA Important Note: display:none hides content but (generally) does not improve performance! Hiding images: Setting parent element to display:none will prevent the image from being loaded.
  • 32. Responsive Menu Options Use unordered list menu layouts: <nav> 
 <ul> 
 <li><a href="/”>Home</a></li> 
 <li><a href="/About.aspx">About</a></li> 
 <li><a href="/Speaking.aspx">Speaking</a></li> 
 <li><a href="/Contact.aspx">Contact</a></li> 
 </ul> 
 </nav>!
  • 33. 1. Flow the menu onto two lines
  • 34. 1. Flow the menu onto two lines What a horizontal unordered list will naturally do Can hide submenu dropdowns (If accessible elsewhere) •  nav ul li ul { display:none; }! Use media queries to reduce font sizes before breaking to two lines
  • 35. 1. Flow the menu onto two lines Tutorial: http://designshack.net/articles/css/ code-a-responsive-navigation-menu
  • 36. 1. Flow the menu onto two lines When to use it? Submenus don’t need to be accessed Items will fit on two lines Items not expected to change often A solution without Javascript is desired Minimal effort desired
  • 37. 2. Switch a horizontal menu to vertical
  • 38. 2. Switch a horizontal menu to vertical Regular CSS: •  nav ul li { float:left; }! Mobile-size CSS: •  @media (max-width: 480px) { 
 nav ul li { float:none; ! ! ! width:100%; }! }! Can hide submenu dropdowns (If accessible elsewhere) •  nav ul li ul { display:none; }!
  • 39. 2. Switch a horizontal menu to vertical Tutorial to include dropdown submenus: http://ejhansel.com/a-responsive-drop-down-navigation-menu •  Based on Suckerfish dropdowns •  Uses :hover to expand submenus
  • 40. 2. Switch a horizontal menu to vertical When to use it? More menu items Longer page names Can choose whether to include submenus A solution without Javascript is desired Minimal effort desired
  • 41. 3. Switch to an expandable menu button
  • 42. 3. Switch to an expandable menu button Similar to switching a horizontal menu to vertical, with the addition of hiding the menu until clicked/touched The markup: <nav> ! !
 ! <a href="#" class=”
 show-mobile">Main Menu</a> ! 
 <ul><li>…</li></ul> !
 </nav>!
  • 43. 3. Switch to an expandable menu button •  Regular CSS: .show-mobile { display: none; }! •  CSS to show the button and hide the menu for mobile: @media (max-width: 768px) { ! !
 nav .show-mobile {
 display: block; }
 nav ul { !
 display: none; } }! •  jQuery for the menu toggle: <script> ! !
 jQuery(".show-mobile").click(function () { 
 jQuery("nav ul").toggle("fast"); !
 });
 <script>
  • 44. 3. Switch to an expandable menu button An in-depth, mobile-first menu tutorial: •  http://azadcreative.com/2012/07/ responsive-mobile-first-navigation-menu •  Uses a mobile menu button toggle, and includes submenus expanding on click/ touch
  • 45. 3. Switch to an expandable menu button When to use it? Want mobile menu to fit in a small area Want a highly stylable, flexible option More menu items and/or longer page names Can choose whether to include submenus Ok with an “extra click” before selecting
  • 46. 4. Switch to a dropdown (select) menu
  • 47. 4. Switch to a dropdown (select) menu Uses efficient native mobile controls Use jQuery to dynamically swap: <nav>
 <ul> 
 <li><a href=“#”>…</a></li> 
 </ul>
 </nav>
 -to- <nav>
 <select> 
 <option value=“#”>…</option>
 </select>
 </nav>! From: http://css-tricks.com/convert-menu-to-dropdown !
  • 48.
  • 49. 4. Switch to a dropdown (select) menu Similar options that switch <ul> to <select>: •  TinyNav.js: –  Uses jQuery, small file size –  https://github.com/viljamis/TinyNav.js •  Responsive Menu: –  Uses jQuery, supports submenus, lots of settings –  https://github.com/mattkersley/Responsive-Menu •  SelectNav.js: –  Inspired by TinyNav, Independent (no jQuery), supports submenus –  http://lukaszfiszer.github.com/selectnav.js
  • 50. 4. Switch to a dropdown (select) menu When to use it? Want mobile menu to fit in a small area Want native controls for the mobile menu More menu items and/or longer page names Want submenus included Ok with an “extra click” before selecting
  • 51. Remember the Viewport Ensure mobile browsers will scale to view your site correctly Include in the <head> : <meta name="viewport" content="width=device-width”>!
  • 52. Resources •  Responsive Web Design (A Book Apart 4) Ethan Marcotte •  MediaQueri.es •  http://bradfrostweb.com/responsive-web- design-newsletter •  http://zomigi.com/blog/essential- considerations-for-crafting-quality-media- queries !
  • 53. Questions? Amelia Marschall-Miller Gravity Works Design + Development Partner & Creative Director GravityWorksDesign.com AmeliaMarschall.com @MimiAmelia