Nifty Penguin Magic


    3.0.3 • Public • Published

    NOTE: This is a fork, published as @gpittarelli/picturefill. Only difference is that this publish is up-to-date with 3.0.3 whereas the main package has gone unpublished for almost a year


    A responsive image polyfill.

    build-status Join Slack channel picturefill on npm

    Picturefill has three versions:

    • Version 1 mimics the Picture element pattern with span elements. It is no longer maintained.
    • Version 2 is a lightweight polyfill of the Picture element draft specification.
    • Version 3.0.3 is the current stable release.

    Usage, Demos, Docs

    To find out how to use Picturefill, visit the project site.

    The gotchas

    Be it browser issues, the responsive images specifications, or Picturefill itself, there are a couple gotchas you should be aware of when working with Picturefill:

    • Firefox 38 and 39 has some bugs [1] [2] [3] where images won't update on screen resize. These issues are addressed by Picturefill 3.0.0, and was fixed in Firefox 41.

    • Per the picture spec, using % isn't allowed in the sizes attribute. Using % will fallback to 100vw.

    • Trying to use the src attribute in a browser that doesn't support picture natively can result in a double download. To avoid this, don't use the src attribute on the img tag:

        <source srcset="../img/sample.svg" media="(min-width: 768px)" />
        <img srcset="default.png" alt="Sample pic" />
    • If you only want to have an image show up at certain sizes, and not show up at others, you will need to use a transparent placeholder gif:
        <source srcset="../img/sample.svg" media="(min-width: 768px)" />
        <img srcset="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=="
            alt="Sample pic" />


    For information on how to contribute code to Picturefill, check out


    If you find a bug in Picturefill, please add it to the issue tracker


    Picturefill discussion takes place via Slack. For an invitation, visit


    There are currently no known unsupported browsers, provided that you use the markup patterns provided.


    npm i @gpittarelli/picturefill

    DownloadsWeekly Downloads






    Unpacked Size

    128 kB

    Total Files


    Last publish


    • gpittarelli