5.0.1 • Published 3 months ago

srcset v5.0.1

Weekly downloads
780,739
License
MIT
Repository
github
Last release
3 months ago

srcset

Parse and stringify the HTML <img> srcset attribute.

Can be useful if you're creating a build-tool.

Install

npm install srcset

Usage

How an image with srcset might look like:

<img
	alt="The Breakfast Combo"
	src="banner.jpg"
	srcset="banner-HD.jpg 2x, banner-phone.jpg 100w"
>

Then have some fun with it:

import {parseSrcset, stringifySrcset} from 'srcset';

const parsed = parseSrcset('banner-HD.jpg 2x, banner-phone.jpg 100w');
console.log(parsed);
/*
[
	{
		url: 'banner-HD.jpg',
		density: 2
	},
	{
		url: 'banner-phone.jpg',
		width: 100
	}
]
*/

parsed.push({
	url: 'banner-super-HD.jpg',
	density: 3
});

const stringified = stringifySrcset(parsed);
console.log(stringified);
/*
banner-HD.jpg 2x, banner-phone.jpg 100w, banner-super-HD.jpg 3x
*/

API

parseSrcset(string, options?)

Parse the HTML <img> srcset attribute.

Accepts a “srcset” string and returns an array of objects with the possible properties: url (always), width, height, and density.

string

Type: string

A “srcset” string.

options

Type: object

strict

Type: boolean\ Default: false

When enabled, an invalid “srcset” string will cause an error to be thrown. When disabled, a best effort will be made to parse the string, potentially resulting in invalid or nonsensical output.

stringifySrcset(SrcSetDefinitions, options?)

Stringify SrcSetDefinitions. Accepts an array of SrcSetDefinition objects and returns a “srcset” string.

srcsetDescriptors

Type: array

An array of SrcSetDefinition objects. Each object should have a url field and may have width, height or density fields. When the strict option is true, only width or density is accepted.

options

Type: object

strict

Type: boolean\ Default: false

Enable or disable validation of the SrcSetDefinition's. When true, invalid input will cause an error to be thrown. When false, a best effort will be made to stringify invalid input, likely resulting in invalid srcset value.

@applitools/snapshot-server-app@infinitebrahmanuniverse/nolb-sr@everything-registry/sub-chunk-2813@tevanoff/test-archiver@dkwasniewski/paczka@devorso/dcountdown@docusaurus/plugin-content-blogfetch-instagram-photosfeed-mefront3from-srcsetexercitationemoptioimg-placeholder-srcimg-scraperhtml-absolutelydwicao-website-scraper@cloudcannon/dist@cloudcannon/suite@explodingcamera/website-scraper@epubkit/generatormggauharnetlify-plugin-lazy-load-imagesgenerator-bootstrap-boilerplate-templatemetalsmith-fingerprint-patch@fwd/scraperpackage-example.jsonpercollatepercollate-fork@frontal/pages-plugin@frodzislaw/front3@nordddb/catalog@prettier-x/formatter-2021-01sindresorhus.jssitescrape@refactorpro/pixi-virtual-joystickreseedsanitize-html-2sanitize-html-hackedsanitize-html-streamsanitize-html-xsticky-scroll-catcha16z-venture-list@alexandravaldez/mdlinks@parcel/transformer-html@smarterlabs/polymorph@smarterlabs/site-downloadercatalogcatalog-docscatalog_ds_docscatalog-guidecna-scrapercloudcastsdowncloudcannon-suiteanalyze-imageastro-htmlnanowebsite-validatorwebsite-scrap-enginewebsite-scraperwebsite-scraper-2website-scraper-fscheck-pageschain_digger@abidibo/js-word-event@alchemy-se/catalog@teamschemaadmin/sanitize-html@sh-winter/vite-plugin-qiankun@use-pluto/satellite@webiny/aws-helpers@webiny/api-prerendering-service@tryghost/mg-assetscraper@tryghost/mg-substack@types/srcsetvue-responsive-img@sysce/stomp@chromaui/test-archiver@catalog/coreposthtml-base-urllf-ui-kitlinkinator@mango-js/parcel-transformer-html
5.0.1

3 months ago

5.0.0

2 years ago

3.0.1

3 years ago

4.0.0

3 years ago

3.0.0

4 years ago

2.0.1

4 years ago

2.0.0

5 years ago

1.0.0

9 years ago

0.1.1

10 years ago

0.1.0

11 years ago