svelte-img
Elegant responsive images for SvelteKit.
Demo: https://zerodevx.github.io/svelte-img/
Install
Install the package:
$ npm i -D @zerodevx/svelte-img
Add imagetools
plugin into your vite.config.js
:
import { sveltekit } from '@sveltejs/kit/vite'
import { imagetools } from '@zerodevx/svelte-img/vite'
const config = {
plugins: [sveltekit(), imagetools()]
}
export default config
Usage
Use anywhere in your Svelte app:
<script>
import cat from '$lib/assets/cat.jpg?run'
import Img from '@zerodevx/svelte-img'
</script>
<Img class="any classes" src="{cat}" alt="Cute cat" />
The image component renders into:
<picture>
<source
type="image/avif"
srcset="path/to/avif/480 480w, path/to/avif/1024 1024w, path/to/avif/1920 1920w"
/>
<source
type="image/webp"
srcset="path/to/webp/480 480w, path/to/webp/1024 1024w, path/to/webp/1920 1920w"
/>
<img
class="any classes"
src="path/to/jpg/480"
srcset="path/to/jpg/480 480w, path/to/jpg/1024 1024w, path/to/jpg/1920 1920w"
loading="lazy"
decoding="async"
style='background: url("data:image/webp;base64,XXX") no-repeat center/cover'
alt="Cute cat"
/>
</picture>
License
ISC