Skip to content

Latest commit

 

History

History
50 lines (36 loc) · 2.44 KB

README.md

File metadata and controls

50 lines (36 loc) · 2.44 KB

Fill Er' Up

Dynamic CSS Injection for base64d SVGs

Totally inspired by http://www.somerandomdude.com/2012/08/12/svg-css-injection/.

Works Like This

  1. Add <script src="fillerup.js"></script> to the bottom of your page
  2. Base64 your SVGs and make them available via classes in your HTML
  3. Add the attribute data-fill with a new fill color.

Example

Live demo

<style>
.icon-user {
    width: 120px;
    height: 130px;
    background-size: 100% 100%;
    display: inline-block;
    background-repeat: no-repeat;
    background-image: url('');
    margin: 15px;
}
</style>
<i class="icon-user"></i>
<i class="icon-user" data-fill="#ec6a38"></i>
<i class="icon-user" data-fill="#7bd454"></i>
<i class="icon-user" data-fill="#00AEEC"></i>
<i class="icon-user" data-fill="random"></i>

Example Screenshot

Fillerup Screenshot

Downsides

  1. Only tried it on a few SVGs
  2. Currently only works with base64d SVGs
  3. Will do weird things if you have multiple <path> elements with individual fill attributes.

Todos

  1. Possible support for hover states, etc.
  2. More optimizations
  3. require.js support?
  4. support for common svg libraries?