Respify responsive image library
A simple responsive images library, which parses an image from a set of child span nodes with data-media and data-src attributes. It uses media queries to select images.
This is an example of how to use Respify. You can view a working example on the example page
Respify can either be used to create or replace the src of a (direct) child img element, or set the CSS background when the 'background'
option is be set to true
.
Respify wil pop from the array of span child nodes, this means that the last node in the list will be parsed first. If Respify finds one matching media query it will use the corresponding image and stop the search.
<span id="default-responsive" class="responsive-img" data-alt="This is an example of a responsive image">
<span data-src="img/[email protected]" data-media="(max-width: 30em)"></span>
<span data-src="img/[email protected]" data-media="(min-width: 30em) and (max-width: 48em)"></span>
<span data-src="img/[email protected]" data-media="(min-width: 48em) and (max-width: 60em)"></span>
<span data-src="img/[email protected]" data-media="(min-width: 60em) and (max-width: 80em)"></span>
<span data-src="img/[email protected]" data-media="(min-width: 80em)"></span>
<noscript><img src="ext/img/[email protected]" alt="A yacht race"></noscript>
</span>
Set up the Javascript like this:
$('#default-responsive').respify();
Respify is a loosely based on the picture tag specification, the major difference is that it can set background image of a tag. Using child span
tags you can supply different size images. Set the data-media tag to specify a media query and use the data-src tag to specify a src image.
Pass options to respify as an object:
$('#default-responsive').respify({
background : true
});
Respify adds an event listener to the resize event and will recalculate the image it has to use.
type: boolean, default: false
wether to place the selected image as a background-image css property or as a img src attribute of a direct img child element. If there is no direct img child tag, one will be added.
type: boolean, default: false
If set to true the plugin will only return the set of matched images and not actually place them on the tags. This can be usefull if you want to supply the selected image to some other piece of code which can not implicitly handle responsive images.
type: Function, default: undefined
Here you can supply a function to Respify, this function will be called whenever a new image is calculted at resize. This is especially usefull in combination with the dryRun setting where the image is not actually set on the picture tag.
Breaking change. Span elements with data-src have to be a direct child of the respified element and include the data-src and data-media attribute.
Revamped. Readme now follows the functionality of the library. Added check for existence of an > img tag of which the src attribute will be replaced when 'background' setting is set to false (= default). If not found it will fallback to the default functionality of adding a child img tag.
Too hasty, package.json now has a version.
Added package.json to be able to install respify with NPM