Varying navbar for mobile and desktop

Look at framer.com in various widths. The navbar is finely tuned based on the device width. As you decrease the device width, the logo moves above the text, then some links disappear (“Pricing”, “Trial”), then some links change their text (“Get Started” becomes “Start”), then the text gets smaller, then finally the links move to two rows.

How does the site achieve this? Using CSS classes like hide-laptop and hide-tablet-s:

<span class="hide-laptop">Get </span>Start<span class="hide-laptop">ed</span>
<li class="hide-tablet-s">
  <a href="/pricing" class="">Pricing</a>
</li>

These classes then have rules like:

@media screen and (max-width: 1024px) {
  .hide-laptop {
    display: none !important;
  }
}

@media screen and (max-width: 600px) {
  .hide-tablet-s {
    display: none !important;
  }
}

The CSS has many categories of device: desktop, laptop, tablet, tablet-s, mobile-l, mobile-m, mobile-s. This seems unnecessarily fine-grained. I think these are sufficient to begin with:

@media screen and (max-width: 768px) { .hide-tablet { display: none !important; } }
@media screen and (max-width: 375px) { .hide-mobile { display: none !important; } }
Tagged .
👋 I'm Jim, a full-stack product engineer. Want to build an amazing product and a profitable business? Read more about me or Get in touch!

More by Jim

This page copyright James Fisher 2017. Content is not associated with my employer. Found an error? Edit this page.