jQuery simple slider / slideshow / caoursel widget that is lightweigt, seo friendly and has fade effect between slide transitions.
The internet is full of false statement that slideshows are bad for search engine optimizations (SEO) or usability. Its not the slideshow that is bad, its how the slider is interpreted and how the designer and developer define the slider technically and visually.
Why else is amazon sometimes using a simple slider at its main page?
Many slider plugins are heavy and bloated with many features for a large target audience of developers, agencys and artists. The more tools you get the more you do without reflecting if it really helps the user.
This plugin does not support animations so with static slides you must analyse what is important for your users intention to reach his target.
- seo optimized for Web Core vitals
- faster loading speed compared to competition
- easy to configure
- fade transition between slides
- responsive
- control buttons
-
- previous and next
-
- slide indicator dots
Content is completely visible in DOM in a natural HTML tag structure and so visible for search engine crawlers.
The CSS stylesheet file and javascript JS file are very small in size.
Web Core Vitals is a framework for search engines to test the quality of a webpage technically and visually. You can check your rating inside google search console or using google test page https://pagespeed.web.dev or developer tool Lighthouse in your browser.
Test it out yourself: Use the example html without the javascript file and see if the first slide is still visible!
An important metric is "Largest contentful paint" (LCP) which represents how fast the upper visible content (above the fold) is rendered and visible to the user. For content below the fold the user must scroll so its less important. First impression counts!
This slider is LCP friendly because the first slide is immediately visible and all other slides hidden, even without the use of javascript. Other slideshow / carousel plugins require javascript to display the first slide which in fact, can hurt your SEO much since the most important "hero" image of the first slide will only load once the resources or even the whole DOM has been loaded which can delay it by a second or more.
Since the javascript code is not needed to display the first slide so the loading of the JS file can be deferred or loaded asynchronously.
Metric cumulated layout shift is an important metric since it measures how much the page will jump during loading which lead to annoying user behavior, especially on mobile small screens.
This slider is CLS friendly since there is no shift if you use a fixed css height
on the slider or if thats not possible repeat the first background <img>
tag after the slides so no additional javascript is required to calculate the height on initialization and windows resizing.
In this tutorial, we'll create a simple image slider for a web page. We'll cover initializing the slider, adding captions, and optimizing images for performance and SEO.
First, add the HTML code for the slider. We use simple images with full width and automatic height.
<div id="slider" class="del-slider">
<!-- slide 1 -->
<div>
<img class="w-full h-auto" src="path_to_your_image1.jpg" alt="Description of the first image" width="1800" height="700"/>
</div>
<!-- slide 2 -->
<div>
<img class="w-full h-auto" src="path_to_your_image2.jpg" alt="Description of the second image" width="1800" height="700"/>
</div>
</div>
This sets up a basic slider where each image will stretch to the full width of the slider container.
Add captions with relative font size (em) to ensure better responsiveness on different screen sizes.
<div id="slider" class="del-slider">
<div>
<img class="w-full h-auto" src="path_to_your_image1.jpg" alt="Description of the first image" width="1800" height="700"/>
<div class="caption" style="position: absolute; top: 20%; left: 10%; font-size: 2em;">
Your caption here
</div>
<!-- img caption -->
<img class="absolute" height="384"src="path_to_your_image1.jpg" height="384" style="width: 30%; height: auto; left: 33%; top: 51%;" width="704" />
</div>
</div>
Position the caption absolutely within the .slide div. Adjust the 'top' and 'left' properties to place the caption as needed.
To determine the height of the slider, repeat the first image at the end of the slider. This improves display and reduces layout shifting.
<div id="slider" class="slider">
<!-- Your slides -->
<!-- Repeat the first image at the end -->
<img src="path_to_your_first_image.jpg" alt="Description of the first image" style="width: 100%; height: auto;">
</div>
This technique helps in maintaining a consistent height for the slider, especially before the JavaScript has loaded.
Optimize image loading by adding loading, fetchPriority, and srcSet attributes.
- loading="lazy" for images that aren't immediately visible.
- fetchPriority="high" for the first or crucial images.
- Use srcSet for responsive image sizes.
<div id="slider" class="slider">
<img src="path_to_your_first_image.jpg" alt="Description of the first image" loading="lazy" fetchPriority="high" style="width: 100%; height: auto;">
</div>
Include alt, width, and height attributes for each image for better SEO performance.
Have a look at this ecommerce shop in production: https://www.call4drinks.de/.
Create an issue if you have feedback, tips or find bugs!
deloma equals SEO