Skip to content

A Pattern for simple Event-Driven Virtual Stylesheets: 100% CSS plus the expressive power of JavaScript

License

Notifications You must be signed in to change notification settings

tomhodgins/js-in-css

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

JS-in-CSS Patterns

Patterns for building simple Event-Driven Virtual Stylesheets. 100% CSS, plus the expressive power of JavaScript!

In this repository

There is a simple JS-in-CSS pattern that can be used for writing individual event-driven virtual stylesheets. You can write CSS code, as well as include JS template string interpolation to compose stylesheets, and trigger recalculations of those stylesheets by listening to JavaScript events.

In addition to writing stylesheets, since you can interpolate JavaScript at any point inside the virtual stylesheet you are able to easily extend your expressive ability by writing JavaScript functions that return CSS code as strings (sometimes in addition to doing other things). I call this writing 'mixins', and there is a very basic mixin pattern included here as well that forms the base of many useful mixins listed below.

Last, to demonstrate some ways in which the JS-in-CSS patterns for writing event-driven virtual stylesheets can be used together with mixins to extend CSS's styling ability I've included a modern container queries demo page that shows off a wide variety of tests that are useful for styling:

And to prove how simple and flexible these patterns are, I've included examples of JS-in-CSS patterns written for legacy versions of IE, demonstrating that this way of building sites has been possible for a long time already and doesn't rely on new features such as Resize Observer or Houdini to achieve (though they will offer some amazing improvements some day!)

Compatible Mixins

Similar JS-in-CSS Patterns

Simple JSinCSS pattern with add, remove, and debounce functions

A JavaScript plugin that adds a process="" attribute to <style> tag in HTML, and makes it easy to reprocess JS-in-CSS on specific JavaScript events

Scope $this in an external stylesheet to a selector (and events)

Interpolate JS anywhere in CSS with ${} inside <style> innerHTML and <link rel=stylesheet href>

CSS with JS interpolation using ${} written using external stylesheets (authored as CSS)

Add JavaScript tests to <link> tags to toggle stylesheets

More Resources

About

A Pattern for simple Event-Driven Virtual Stylesheets: 100% CSS plus the expressive power of JavaScript

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published