web-dev-qa-db-fra.com

SEO - redimensionner une seule image avec CSS ou générer des vignettes à partir de cette image

J'ai 4 tailles pour une seule image dans une page de mon site Web de commerce électronique. 600x600px, 350x350px, 220x220px, 110x110px

Il y a 3 solutions:

1- Charger la grande image (600x600px) à partir du serveur et la mettre en cache, puis générer des vignettes à l'aide de la vignette mise en cache par un plugin côté client.

2- Chargement de la grande image et des vignettes à partir du serveur. (dans ce cas, les vignettes sont générées sur le serveur)

3- Charger la grande image et créer des vignettes en redimensionnant la grande en utilisant CSS. (ou, par exemple, nous pouvons charger ceux de 600x600px et 350x350px et créer des vignettes par CSS à partir de 350x350px)

Quelle solution est la meilleure pour le référencement? ou s'il y a un autre moyen, j'apprécie.

2
Payam Shakibafar

Les solutions 1 et 3 sont à peu près les mêmes, le n ° 1 faisant un pas inutile pour une économie négligeable sur la bande passante - car le redimensionnement CSS de la n ° 3 convient assez bien. Pour gagner vraiment de la bande passante, avec l’avantage SEO implicite que le site se chargerait beaucoup plus rapidement, utilisez la solution n ° 2.

1
Lucian Davidescu

L’efficacité de la bande passante semble être prise en compte dans le référencement, mais seuls les moteurs de recherche connaissent la pondération secrète qu’ils lui appliquent.

Si, par exemple, votre site Web utilise un grand nombre d’images téléchargées à une résolution supérieure à celle requise et qu’elles sont ensuite redimensionnées à une taille fixe dans le code HTML/CSS, cela peut entraîner une pénalité de référencement, car ils pensent que vous devez fournir l’image au début. taille appropriée utilisée par votre page pour réduire l'utilisation de la bande passante et le traitement côté client.

Toutefois, dans les cas où la taille de la vignette requise dépend de la taille de l'écran ou de l'orientation du périphérique client, vous pouvez utiliser les requêtes de support CSS pour spécifier le fichier image de vignette correct, puis appliquer la mise à l'échelle à l'aide de CSS aux endroits requis. La pénalité de référencement pour les images de taille incorrecte ne semble pas s'appliquer aux images spécifiées dans le cadre de requêtes multimédia CSS.

<style type="text/css">
.thumb {
  background-image: url('https://lh4.ggpht.com/wKrDLLmmxjfRG2-E-k5L5BUuHWpCOe4lWRF7oVs1Gzdn5e5yvr8fj-ORTlBF43U47yI=w300');
  background-repeat: no-repeat;
}
@media (min-width: 600px) {
  .thumb {
    background-size: 600px;
    height: 600px;
    width: 600px;
  }
}
@media (max-width: 599px) {
  .thumb {
    background-size: 300px;
    height: 300px;
    width: 300px;
  }
}
</style>

<div class="thumb"></div>

Une image peut être redimensionnée en CSS. Par exemple, si vous aviez une image de 300 x 300 pixels, vous utiliseriez max-width/height pour réduire, min-width/height pour réduire (avec certaines images, cela ne sera pas forcément terrible). :

<style type="text/css">
img.thumb110 { max-width: 110px; max-height: 110px; }
img.thumb220 { max-width: 220px; max-height: 220px; }
img.thumb350 { min-width: 350px; min-height: 350px; }
img.thumb600 { min-width: 600px; min-height: 600px; }
</style>

<img class="thumb110" src="example.png" />
<img class="thumb220" src="example.png" />
<img class="thumb350" src="example.png" />
<img class="thumb600" src="example.png" />

La meilleure méthode dépendra du fonctionnement de votre site Web et de ce qui signifiera le moins de transfert de bande passante nécessaire au téléchargement du contenu requis pour la page.

Si vous demandez au serveur de faire le gros travail en termes de génération de vignettes redimensionnées à la demande, conservez-les au moins pour celles-ci, sauvegardez-les pour une utilisation ultérieure, afin que votre serveur ait à le faire et améliore la vitesse de la page.

Pour toutes les pages de commerce électronique comportant de nombreuses miniatures, il peut être préférable d’incorporer les images miniatures sous forme de données dans le code HTML plutôt que de demander au navigateur d’exécuter une demande HTTP GET distincte pour chaque image. Par exemple:

<img src="" />
0
richhallstoke