# Nuxt Optimized Images

Automatically optimizes images used in Nuxt.js projects (JPEG, PNG, SVG, WebP and GIF).

This module is inspired by the work of Cyril Wanner in next-optimized-images.

# Features

Image sizes can often get reduced up to 60%, but this is not the only thing @mole-inc/nuxt-optimized-images does:

  • Reduces image size by optimizing images during build.
  • Improves loading speed by providing progressive images (for formats that support it).
  • Inlines small images to save HTTP requests and additional roundtrips.
  • Adds a content hash to the file name so images can get cached on CDN level and in the browser for a long time (This is the default behavior of Nuxt.js).
  • Same image URLs over multiple builds for long time caching.
  • Provides query params for file-specific handling/settings.
  • JPEG/PNG images can be converted to WebP on the fly for an even smaller size.
  • Can resize images or generate low-quality image placeholders (lqip).

# Installation

npm install --save-dev @mole-inc/nuxt-optimized-images

or

yarn add --dev @mole-inc/nuxt-optimized-images

WARNING

Node >= 10 and Nuxt.js >= 2 are required.

Add @mole-inc/nuxt-optimized-images to buildModules section of nuxt.config.js:

⚠️ If you are using Nuxt < 2.9.0, use modules instead.

{
  buildModules: [
    '@mole-inc/nuxt-optimized-images',
  ],

  optimizedImages: {
    optimizeImages: true
  }
}

See the configuration section for all available options.

TIP

Images won't get optimized out of the box. You have to install the optimization packages you really need in addition to this module.

This doesn't force you to download big optimization libraries you don't even use. Please check out the table of all optional optimization packages.

# Optimization Packages

You have to install the optimization packages you need in your project in addition to this module. Then, @mole-inc/nuxt-optimized-images detects all the supported packages and uses them.

So you only have to install these packages with npm, there is no additional step needed after that.

The following optimization packages are available and supported:

Optimization Package Description Project Link
@mole-inc/imagemin-mozjpeg Optimizes JPEG images Link
@mole-inc/imagemin-jpegoptim Optimizes JPEG images Link
@mole-inc/imagemin-pngquant Optimizes PNG images Link
@mole-inc/imagemin-optipng Alternative for optimizing PNG images Link
imagemin-gifsicle Optimizes GIF images Link
imagemin-svgo Optimizes SVG images and icons Link
@mole-inc/webp-loader Optimizes WebP images and can convert JPEG/PNG images to WebP on the fly (WebP resource query) Link
@mole-inc/lqip-loader Generates low quality image placeholders of an image (lqip resource query) Link
responsive-loader Can resize images on the fly and create multiple versions of it for a srcSet. Important: You need to additionally install either jimp (node implementation, slower) or sharp (binary, faster) Link
sqip-loader Loads images and exports tiny SQIP previews as image/svg+xml URL-encoded data Link

Example: If you have JPG, PNG, and SVG images in your project, you would then need to run

npm install --save-dev @mole-inc/imagemin-mozjpeg @mole-inc/imagemin-pngquant imagemin-svgo

# or

yarn add --dev @mole-inc/imagemin-mozjpeg @mole-inc/imagemin-pngquant imagemin-svgo

To install all optional packages, run:

npm install --save-dev @mole-inc/imagemin-mozjpeg @mole-inc/imagemin-jpegoptim @mole-inc/imagemin-pngquant imagemin-gifsicle imagemin-svgo @mole-inc/webp-loader @mole-inc/lqip-loader responsive-loader sqip-loader sharp

# or

yarn add --dev @mole-inc/imagemin-mozjpeg @mole-inc/imagemin-jpegoptim @mole-inc/imagemin-pngquant imagemin-gifsicle imagemin-svgo @mole-inc/webp-loader @mole-inc/lqip-loader responsive-loader sqip-loader sharp

WARNING

Please note that by default, images are only optimized for production builds, not development builds. However, this can get changed with the optimizeImagesInDev config.

TIP

Depending on your build/deployment setup, it is also possible to install these as devDependencies. Just make sure that the packages are available when you build your project.