Feb is.me
Back

CSS and Javascript media queries

01/10/2021 · by Feb Dao
Profile picture of Marc Backes (very handsome) Profile picture of Feb Dao(very handsome)

The responsive display is an important thing in web design, it can't be done without using media queries.

Bug, Error, Defect, Failure Explained

CSS Media Queries:

CSS media queries are a core in the responsive design, the @media rule is used in media queries allows the front-end developer can apply different styles to different media types/devices.

In a CSS file, the media queries looks like this:

.menu {
  font-size: 20px;
}

@media (min-width: 1024px) {
  .menu {
    font-size: 16px;
  }
}

They can be used to check:

  • Width and height of the viewport
  • Width and height of the device
  • Orientation (landscape or portrait mode)
  • Resolution

Using media queries are a popular technique for delivering a style sheet to desktops, laptops, tablets and mobile display. You can also use media queries to specify the styles are only for printed documentation or screen readers.

@media only screen and (orientation: landscape) {
  body {
    background-color: lightblue;
  }
}

@media screen {
  body {
    color: green;
  }
}

@media print {
  body {
    color: black;
  }
}

@media screen and (max-width: 992px) {
  .column {
    width: 50%;
  }
}

Media features also provide more specific details to media queries, for example: you can apply styles for only the screens that are greater or smaller than a width.

@media screen and (max-width: 900px) and (min-width: 600px), (min-width: 1100px) {
  body {
    background: yellow;
  }
}

SASS/SCSS mixins

In the real projects, I usually use SCSS, this is how I make the Media queries mixins.

First of all, we need to have the breakpoint variables in file _variables.scss

// Media breakpoints
$sm: 576px;
$md: 768px;
$lg: 990px;
$xl: 1200px;

Then we can create mixins like this

// Media query
@mixin miw($media) {
  @media (min-width: $media) { @content; }
}

@mixin maw($media) {
  @media (max-width: $media - 0.02px) { @content; }
}

Now, when you want to use the media queries, just do

.btn {
    margin-bottom: 0;

    @include min($md) {
      + .btn {
        margin-top: 10px;
      }
    }

    @include maw($lg) {
      + .btn {
        margin-top: 20px;
      }
    }
  }

We will have:

.btn {
  margin-bottom: 0;
}

@media (min-width: 768px) {
  .btn + .btn {
    margin-top: 10px;
  }
}

@media (max-width: 990px) {
  .btn + .btn {
    margin-top: 20px;
  }
}

Javascript Media Queries:

Working with media queries in JavaScript is very different than working with them in CSS, even though the concepts are similar: match some conditions and apply some stuff.

There are 2 ways to implement the Javascript media queries

1. The old way

This is the most common approach, it's binding a resize event, then check the window.innerWidth with the resize function

function checkMediaQuery() {
  if (window.innerWidth > 576) {
    console.log('Larger than Small Media Query Matched!');
  }

  if (window.innerWidth > 768) {
    console.log('Larger than Medium Media Query Matched!');
  }

  if (window.innerWidth > 990) {
    console.log('Large Media Query Matched!');
  }
}

// Initial check
checkMediaQuery();

// Add a listener for when the window resizes
window.addEventListener('resize', checkMediaQuery);

2. Using the matchMedia()

To determine if the document matches the media query string in Javascript, we can use the matchMedia() method. The usage is nearly like CSS media queries, we need to pass the media query string to matchMedia() then check the .matches property.

const mediaQuerySm = window.matchMedia('(min-width: 576px)');
const mediaQueryMd = window.matchMedia('(min-width: 768px)');
const mediaQueryLg = window.matchMedia('(min-width: 990px)');

Then we can check it the .matches returns true

// Check if the media query is true
if (mediaQuerySm.matches) {
  alert('Larger than Small Media Query Matched!')
}

if (mediaQueryMd.matches) {
  alert('Larger than Medium Media Query Matched!')
}

if (mediaQueryLg.matches) {
  alert('Large Media Query Matched!')
}

Finally, we can listen for the changes

function handleResizeChange(e) {
  // Check if the media query is true
  if (e.matches) {
    // Then log the following message to the console
    console.log('Media Query Matched!')
  }
}

// Register event listener
mediaQuerySm.addListener(handleResizeChange);
mediaQueryMd.addListener(handleResizeChange);
mediaQueryLg.addListener(handleResizeChange);

// Initial check
handleResizeChange(mediaQuerySm);
handleResizeChange(mediaQueryMd);
handleResizeChange(mediaQueryLg);
with love by Feb Dao © 2021
built with nuxt