Name Modified Size
LICENSE.md3 years ago1.09 KB
README.md3 years ago1.96 KB
altclass.js3 years ago2.64 KB
altclass.legacy.js3 years ago3.28 KB
altclass.legacy.min.js3 years ago1.29 KB
altclass.min.js3 years ago1016
bower.js3 years ago524
demo.html3 years ago5.45 KB


altclass lets you assign responsive classnames by element breakpoints.

Create three classname combinations in a single attribute.

<div data-altclass="widget, size-s 640 size-m 960 size-l">

When the element is less than 640px:

<div class="widget size-s">

Or between 640px and 959px:

<div class="widget size-m">

Or 960px and beyond:

<div class="widget size-l">

How it works

altclass.js places a completely hidden iframe with no layout inside an element to detect its changes. When the element’s width matches a new altclass breakpoint, its classnames are refreshed.

The iframe has no height, so elements with dynamic content that change their height will not trigger unnecessary measurements or calculations. Similarly, window resizes that do not change the width of the element will not trigger unnecessary measurements or calculations.


The data-altclass attribute is a collection of breakpoints separated by commas.

<div data-altclass="[breakpoint list]">

<div data-altclass="[breakpoint list], [breakpoint list]">

Breakpoints are a collection of classnames separated by widths.

<div data-altclass="[classname]">

<div data-altclass="[classname] [classname] [width]">

<div data-altclass="[width] [classname]">

<div data-altclass="[classname] [width] [classname] [classname] [width] [classname]">

A classname is activated when the element is as wide as the width before it and less wide than the width after it.

<div data-altclass="[less than 320] 320 [at least 320 & up to 479] 480 [at least 480]">

Altclasses can be assigned and reassigned in JavaScript.

document.querySelector('.widget').dataset = "widget, widget--s 640 widget--m 960 widget--l 1200 widget-xxl";

Have fun.

The fully-documented script is 2.64KB, or 618B minified + gzipped. The IE8-compatible legacy script is 3.27KB, or 765B minified + gzipped.