Coder Social home page Coder Social logo

adamsanderson / container-query-polyfill Goto Github PK

View Code? Open in Web Editor NEW

This project forked from googlechromelabs/container-query-polyfill

1.0 1.0 0.0 123 KB

A polyfill for CSS Container Queries

Home Page: https://npm.im/container-query-polyfill

License: Apache License 2.0

TypeScript 39.91% HTML 54.85% CSS 0.74% JavaScript 4.50%

container-query-polyfill's Introduction

Container Query Polyfill

A tiny polyfill for CSS Container Queries, weighing about 1.6kB brotli’d. It transpiles CSS code on the client-side and implements Container Query functionality using ResizeObserver and MutationObserver.

Usage

Ideally, the polyfill is only loaded if the browser doesn’t support Container Queries natively. In a modern setup with a bundler that uses ES modules, the following snippet should work:

const supportsContainerQueries = "container" in document.documentElement.style;
if (!supportsContainerQueries) {
  import("container-query-polyfill");
}

If you are in a legacy setup (or just want to prototype quickly), there’s also an IIFE version that you can include using a <script> tag:

<script src="https://unpkg.com/container-query-polyfill/cqfill.iife.min.js"></script>

Browser support

The polyfull should work in all modern browsers. Chrome 88+, Firefox 78+ and Safari 14+.

Limitations

To keep the polyfill performant, small and maintainable, I have make certain tradeoffs with full feature parity of the Container Query spec. I have listed these tradeoffs below.

(These decisions can be revisited if they pose a significant hurdle and there is a good way to implement them. Please open an issue!)

  • Container Queries will not work when nested inside a Media Query. For now, the polyfill only supports top-level CQs.
  • Container query thresholds can only be specified using pixels.
  • Due to the nature of CORS, the polyfill only attempts to handle same-origin and inline stylesheets. Cross-origin stylesheets are ignored, regardless of CORS headers.
  • Don’t do weird interspersed comments, okay? Like @container /* here’s a comment! */ (min-width: 1px) { ... }. Just don’t.

License Apache-2.0

container-query-polyfill's People

Contributors

surma avatar

Stargazers

 avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.