Skip to content

Client-side support for CSS custom properties (aka "CSS variables") in legacy and modern browsers

License

Notifications You must be signed in to change notification settings

jhildenbiddle/css-vars-ponyfill

Folders and files

NameName
Last commit message
Last commit date

Latest commit

895cc48 Β· Mar 5, 2024
Mar 5, 2024
Feb 15, 2020
Mar 5, 2024
Jul 29, 2022
Aug 27, 2021
Nov 5, 2020
Aug 26, 2021
Apr 22, 2019
Dec 9, 2018
Mar 5, 2024
Jan 26, 2018
Mar 5, 2024
Jul 29, 2022
Mar 5, 2024
Mar 5, 2024
Jul 31, 2022
Apr 23, 2019

Repository files navigation

css-vars-ponyfill

NPM GitHub Workflow Status (master) Codacy code quality Codacy branch coverage License: MIT jsDelivr Sponsor this project

A ponyfill that provides client-side support for CSS custom properties (aka "CSS variables") in legacy and modern browsers.

Features

  • Client-side transformation of CSS custom properties to static values
  • Live updates of runtime values in both modern and legacy browsers
  • Transforms <link>, <style>, and @import CSS
  • Transforms relative url() paths to absolute URLs
  • Supports chained and nested var() functions
  • Supports var() function fallback values
  • Supports web components / shadow DOM CSS
  • Watch mode auto-updates on <link> and <style> changes
  • UMD and ES6 module available
  • TypeScript definitions included
  • Lightweight (6k min+gzip) and dependency-free

Limitations

  • Custom property declaration support is limited to :root and :host rulesets
  • The use of var() is limited to property values (per W3C specification)
  • CSS changes made using CSSOM APIs are not supported (see #19, #23, #77, #154).

Browser Support

Chrome 19+
Edge 12+
Firefox 6+
IE 9+
Safari 6+

Usage & Options

See the documentation site for details.

Sponsorship

A sponsorship is more than just a way to show appreciation for the open-source authors and projects we rely on; it can be the spark that ignites the next big idea, the inspiration to create something new, and the motivation to share so that others may benefit.

If you benefit from this project, please consider lending your support and encouraging future efforts by becoming a sponsor.

Thank you! πŸ™πŸ»

Contact & Support

  • Follow πŸ‘¨πŸ»β€πŸ’» @jhildenbiddle on Twitter and GitHub for announcements
  • Create a πŸ’¬ GitHub issue for bug reports, feature requests, or questions
  • Add a ⭐️ star on GitHub and 🐦 tweet to promote the project
  • Become a πŸ’– sponsor to support the project and future efforts

License

This project is licensed under the MIT License. See the MIT LICENSE for details.

Copyright (c) John Hildenbiddle (@jhildenbiddle)