npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

object-fit-polyfill

v0.1.0

Published

Polyfill for the CSS object-fit property

Downloads

7,955

Readme

Polyfill for CSS object-fit property

object-fit alows you to define the sizing mode for content images (like background-size for CSS background sources). Neither IE or Edge has support for this property but common browsers have full support. It's a very useful feature but if you want to target all users and offer a good experience you will need this polyfill.

Browser Support & Feature Detection

This polyfill works with all browsers but uses a feature detection method to see if object-fit is supported. If it's not it will active itself.

Installation

This polyfill is available as Bower component or via npm. Use it right away from bower:

$ bower install --save object-fit-polyfill

or set up via npm

$ npm install --save object-fit-polyfill

Or set up manually by grabbing the download from GitHub. Then include the JavaScript file polyfill.object-fit.min.js at the bottom of your HTML <body>.

Usage

Add the data-object-fit tag to the images you need to use this css property and set any kind of object-fit value (fill,none,contain or cover)

<img src="image.jpg" data-object-fit="cover">

You can find more sample implementations in the examples directory.

Where is the magic?

There is no magic behind this polyfill. The idea is to replace the image with a div using the actual image as background, but mantaining the actual css classes and computed styles.

About The Webstandard

The specification for object-fit is to be found at W3C CSS3 Images. The property scales the image to fit in a certain way into a defined area, e.g:

img {
	width: 100%; // dimensions are mandatory
	height: 35em; // dimensions are mandatory
	object-fit: cover;
	overflow: hidden; // Cuts off the parts of the image poking out
}

Normally, the image would be stretched to the specified dimensions but due to the usage of the CSS property object-fit: cover; the image now is scaled proportionally, until every pixel of the defined area is covered by parts of it. In the case of cover this means that parts of the image will overlap the given area.

The following are the possible values and their implications:

  • fill streches the image exactly to the defined dimensions which results in a distorted image. Comparable to background-size: 100% 100%. That's the default value.
  • none leaves the image at its natural size and centers it inside within the defined area. If the image's natural dimensions are larger than the defined area parts of the image will poke out of it unless you also set overflow: hidden on it. Comparable to background-size: auto auto; background-position: center center.
  • contain scales the image up or down until all of it fits into the defined area. This mode respects the image's natural aspect-ratio. It's also called "letterbox view". Comparable to background-size: contain.
  • cover scales the image up or down until every pixel of the defined area is covered with parts of the image. Sort of "pan and scan view". This means that parts of the image will poke out of the defined area unless you also set overflow: hidden on it. This mode respects the image's natural aspect-ratio. Comparable to background-size: cover.

How object-fit works

Author

This polyfill is written by Toni Pinel.

License

This project is under the MIT Open Source License. See the LICENSE file for more information.