# CSS Element Queries [![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/marcj/css-element-queries?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge) Element Queries is a polyfill adding support for element based media-queries to all new browsers (incl. IE7+). It allows not only to define media-queries based on window-size but also adds 'media-queries' functionality depending on element (any selector supported) size while not causing performance lags due to event based implementation. It's a proof-of-concept event-based CSS element dimension query with valid CSS selector syntax. Features: - no performance issues since it listens only on size changes of elements that have element query rules defined through css. Other element query polifills only listen on `window.onresize` which causes performance issues and allows only to detect changes via window.resize event and not inside layout changes like css3 animation, :hover, DOM changes etc. - no interval/timeout detection. Truly event-based through integrated ResizeSensor class. - automatically discovers new DOM elements. No need to call javascript manually. - no CSS modifications. Valid CSS Syntax - all CSS selectors available. Uses regular attribute selector. No need to write rules in HTML/JS. - supports and tested in webkit, gecko and IE(10+) - `min-width`, `min-height`, `max-width` and `max-height` are supported so far - works with any layout modifications: HTML (innerHTML etc), inline styles, DOM mutation, CSS3 transitions, fluid layout changes (also percent changes), pseudo classes (:hover etc.), window resizes and more - no Javascript-Framework dependency (works with jQuery, Mootools, etc.) - Works beautiful for responsive images without FOUC More demos and information: http://marcj.github.io/css-element-queries/ ## Examples ### Element Query ```css .widget-name h2 { font-size: 12px; } .widget-name[min-width~="400px"] h2 { font-size: 18px; } .widget-name[min-width~="600px"] h2 { padding: 55px; text-align: center; font-size: 24px; } .widget-name[min-width~="700px"] h2 { font-size: 34px; color: red; } ``` As you can see we use the `~=` [attribute selector](https://developer.mozilla.org/en-US/docs/Web/CSS/Attribute_selectors). Since this css-element-queries polyfill adds new element attributes on the DOM element (`
`) depending on your actual CSS and element's dimension, you should always use this attribute selector (especially if you have several element query rules on the same element). ```html ``` ### Responsive image ```html