Skip to content

image-manifest

image-manifest

Инструмент командной строки, который конвертирует изображения в нужный формат, генерирует структуру файлов в формате JSON и при необходимости изменяет размеры. Полезен для статических сайтов, галерей и автоматизации.

npx image-manifest --help покажет все доступные опции.

📖 Использование

Создайте папку img-src

shell
mkdir img-src

Поместите изображения в img-src

shell
npx image-manifest@latest

💻 Параметры командной строки

ПараметрОписаниеПо умолчанию
--src, -sИмя исходной папкиimg-src
--dist, -dИмя папки с результатамиimg-dist
--format, -fВыходной формат: webp, jpg, png, avif или исходный (original)webp
--json, -jИмя выходного JSON-файла (или --no-json, чтобы пропустить)null
--width, -WМаксимальная ширина изображения в пикселяхnull
--height, -HМаксимальная высота изображения в пикселяхnull
--concurrency, -cМаксимум одновременно обрабатываемых изображений5
--include-sizeВключить размеры изображений (ширину и высоту) в JSONfalse
--manifest-onlyТолько генерация JSON-манифеста, без конвертации изображенийfalse
--interactive, -iПринудительный интерактивный режим, даже если переданы аргументыfalse

✨ Примеры

shell
# Конвертировать все изображения в webp (по умолчанию) и создать манифест
npx image-manifest --json static-images --format original

# Изменить размер до максимальной высоты 2000px, другая исходная папка
npx image-manifest --src sources --height 2000

# Только создать JSON-манифест из существующих изображений (без обработки)
npx image-manifest --manifest-only --json gallery --src myimages

# Запустить интерактивный режим (запрашивает все параметры)
npx image-manifest --interactive

⚙️ Файл конфигурации

Вы можете хранить настройки в файле конфигурации, чтобы не передавать их каждый раз в командной строке. Допустимые файлы (поиск в текущей директории и выше):

  • .image-manifestrc.json
  • .image-manifestrc.yaml
  • .image-manifestrc.yml
  • .image-manifestrc.js
  • image-manifest.config.js
  • свойство "image-manifest" в package.json

Пример .image-manifestrc.json:

json
{
  "src": "my-images",
  "format": "webp",
  "json": "gallery",
  "width": 1200,
  "includeSize": true
}

При запуске npx image-manifest без аргументов будет автоматически использован файл конфигурации, если он существует. В противном случае запустится интерактивный режим.

📦 Программный API

Вы также можете использовать image-manifest как библиотеку в своих скриптах.

ts
import { run } from 'image-manifest';

await run({
  src: 'photos',
  dist: 'output',
  format: 'webp',
  json: 'manifest',
  width: 800,
  height: null,
  concurrency: 4,
  includeSize: true,
  // manifestOnly: true  // раскомментируйте, чтобы пропустить конвертацию
});

Пользователи TypeScript могут импортировать типы манифеста:

ts
import type { ImageManifest, ImageFile } from 'image-manifest';