Как конвертировать " type="image/webp">
    <source srcset="" type="image/jpeg">
    <img src="">
</picture>

Другим вариантом может быть использование Modernizr для определения того, может ли браузер клиента использовать webp. Вы можете проверить и создать Modernizr специально для обнаружения webp. Проверьте это здесь.

Что вам нужно сделать, если у вас есть контроль над тем, как изображения создаются/загружаются, так это иметь версию jpg/png и webp и просто использовать соответствующие версии по мере необходимости. Вам нужно иметь оба, потому что, как я уже говорил, webp по-прежнему совместим не со всеми браузерами.

Если вы запустите фрагмент, вы увидите, что если вы попытаетесь загрузить изображение, оно будет использовать версию webp. Если вы откроете его из Safari, он загрузит версию jpg.

ОБНОВЛЕНИЕ 2. Преобразование изображений

Что касается преобразования изображения, вы можете либо создать функцию генерации изображения, которая получает изображение webp в качестве параметра и возвращает изображение jpg.

Поскольку вы получаете изображение в формате base64, вы можете использовать эту тему, чтобы сохранить изображение на своем сервере, но в .webp в вашем случае. После этого вы можете использовать функцию imagecreatefromwebp() для создания нового изображения. . Проверьте пример в конце этой страницы. Он преобразует изображение webp в jpeg.

Из того, что я вижу, вы можете сделать что-то вроде:

  1. Получите вызов API, содержащий информацию об изображении.
  2. Проверьте, существует ли ваше изображение на вашем сервере (в идеале создать определенную папку и использовать то же имя изображения).
  3. Если он существует, вы возвращаете путь к изображению.
  4. Если он не существует, вы создаете файл .webp из данных base64. Затем вы конвертируете его в файл .jpg или .png в зависимости от ваших потребностей.
  5. Вы используете локальный образ. Это также может ускорить ваши звонки.
person Mihail Minkov    schedule 10.02.2020
comment
Не могли бы вы проверить картинку, которую я только что добавил в пост? синтаксис, который вы использовали в качестве источника, отличается от того, что я получил - person nix_; 10.02.2020
comment
Да, это больше похоже на мою проблему, но мне интересно, как вы конвертировали из webp в png и jpeg? И я использую React Native, поэтому у меня нет тега изображения. - person nix_; 11.02.2020
comment
О, ну, вам придется сделать преобразование, вероятно, на стороне сервера. Что вы строите? Кроме того, обрабатывает ли API параметр формата изображения? - person Mihail Minkov; 12.02.2020
comment
Я использую php в качестве сценариев на стороне сервера, и единственный формат, который я могу получить из API (serpapi), — это webp. - person nix_; 12.02.2020
comment
@NjoodAdel Я добавил дополнительную информацию о том, как это может работать. - person Mihail Minkov; 12.02.2020