Introduction
If you have been reading my website from the start you would have read this tutorial:
Simple jQuery Image Slide Show with Semi Transparent CaptionIt's a very famous post because it has been showcased in several major web design blogs so many times and I received a lot of traffic from it. Thanks guys. I get a lot of comment and as I replied to those comments and do some quick fixes, I realized that this script has a caption bug and inefficient and not up to standard (oh well, that's the time when I was start picking up jQuery :)), so I have decided to do revisit to solve all those problems discovered by readers. I rewrote the html structure and modify the script.
Mission Objectives:
- Restructure the HTML, more semantic
- Fix the caption bug, it displays the next caption too fast
- W3C standard compliant, using appropriate attribute to store title and description
- Cross Browser - Chrome, Safari, IE6, 7, 8 and Firefox.
However, one thing though, it needs javascript, if your browser is javascript disabled, sorry, there is no graceful degradation for this script, it will just display the first item.
1. HTML
Yes, I'm using list this time :) This is how it should have been afterall. No more REL attribute, we wil be using TITLE Attribute to store the heading and ALT attribute to store the description. For the caption elements, it will be added using jQuery. So, this is it - a clean and simple HTML code.
<ul class="slideshow"> <li class="show"><a href="#"><img data-src="images/s1.gif" width="450" height="200" title="Slide 1" alt="Short Description"/></a></li> <li><a href="#"><img data-src="images/s2.gif" width="450" height="200" title="Slide 2" alt="Short Description"/></a></li> <li><a href="#"><img data-src="images/s3.gif" width="450" height="200" title="Slide 3" alt="Short Description"/></a></li> </ul>
2. CSS
CSS code is rewritten completely. I guarantee it's cross browser compliant. They all look identical and it works great :) I did learn a lot of CSS technique through this blog. We all can improve our skills through tips, tricks, trials and errors. Read these posts to learn more about CSS:
body { font-family:arial; font-size:12px; } ul.slideshow { list-style:none; width:450px; height:200px; overflow:hidden; position:relative; margin:0; padding:0; } ul.slideshow li { position:absolute; left:0; right:0; } ul.slideshow li.show { z-index:500; } ul img { border:none; } #slideshow-caption { width:450px; height:70px; position:absolute; bottom:0; left:0; color:#fff; background:#000; z-index:500; } #slideshow-caption .slideshow-caption-container { padding:5px 10px; z-index:1000; } #slideshow-caption h3 { margin:0; padding:0; font-size:14px; } #slideshow-caption p { margin:5px 0 0 0; padding:0; }
3. Javascript
We will going to use call back function to display caption. This will solve the "Caption Is Appearing Before The Next Slide Syndrome" :). Not too much of changes in javascript but I do added a feature though. On mouse over the slide will pause, and resume it back on mouse out. I think it's a good touch.
$(document).ready(function() { //Execute the slideShow, set 4 seconds for each images slideShow(2000); }); function slideShow(speed) { //append a LI item to the UL list for displaying caption $('ul.slideshow').append('
Updates
2010-09-10: Thanks to Rezzie who nailed the IE8 issue! :)
Updated the article and scripts, the link issue is fixed. :) Sorry for the delay.
Speed Issue
This is one of the issue that has been haunted me for a while, but thanks to Sam, one of our reader, he pointed out this would solve the issue, but with mixed result in IE.
Sam's solution, you need to add this:
$(window).focus(function () { timer = setInterval('gallery()', speed); }); $(window).blur(function () { clearInterval(timer); });
James Burnett's solution, you modify the gallery function():
function gallery() { var current = ($('ul.slideshow li.show')? $('ul.slideshow li.show') : $('#ul.slideshow li:first')); if(current.queue('fx').length == 0) { // grab next image and animate code in here ...... ...... ...... } }
Also, did some research, found the reason why it's doing it: From jQuery Animate Documentation: Because of the nature of requestAnimationFrame(), you should never queue animations using a setInterval or setTimeout loop. In order to preserve CPU resources, browsers that support requestAnimationFrame will not update animations when the window/tab is not displayed. If you continue to queue animations via setInterval or setTimeout while animation is paused, all of the queued animations will begin playing when the window/tab regains focus. To avoid this potential problem, use the callback of your last animation in the loop, or append a function to the elements .queue() to set the timeout to start the next animation.
Sorry guys, I don't have time to put all these together. Please let me know it works.
Randomize Slides
Simple yet effective solution from another reader - Blastos
Before the ending of function slideShow(), put this in:
//Generate a random number var randNum = Math.floor(Math.random() * $('ul.slideshow li').length); //Randomly pick up a slide $('ul.slideshow li:eq('+randNum+')').addClass('show');
Caption doesn't appear for the first slide
I think it has to be the ommitted A tag for some users. Ammended the script, it should be fixed now.
Conclusion
I have made a lot of tutorials, and I think it's good to do a revisit to make it more efficient and solve some of the annoying bugs instead of quick fixes. So, yea, from now on, I will check my previous tutorials and rewrite them. :)
Like this tutorials? You can express your gratitude by visiting my sponsors on the sidebar, bookmark it and help me to spread this tutorial to our friends! :) Thanks!
Comments will be moderated and
rel="nofollow"
will be added to all links. You can wrap your coding with[code][/code]
to make use of built-in syntax highlighter.I already have a gallery set with JQuery. Clicking a tumbnail brings the big image as an overlay.
Can I apply the part of the CAPTION sliding-up over the big image when it's called? All I found so far is captions with mouseover. (website to be compatible for iPads...no mouse)
If so, I'd be thankfull for any information on how to do it.
Thank you.
Basically I made timer variable as global, and clear it once it reached the last slide in gallery function.
im having one issue, when i put it on my site it has made my lightbox not work, when you click on the image it just shows the image in another window instead of using the lightbox effect. Im not to sure why its doing this.
any help would be good.
thanks Joe
Thanx in advice!
Installed this slider. Everything works nicely, but now 'they' want a manual function to scroll through the slides as well as the automatic function
Is there a way to add previous and next button for manual option to this slider or do I have to install a different one?
Thanks so much!
http://dl.dropbox.com/u/7803192/Sullivan/Further%20Resources/slideshow.html
Has buttons to move to next or previous and circles at the top allow you to jump to a specific slide (and indicate the current slide).
Tried your take on the slider and have a few issues. 1) slideshowBox has more dots than there are slides? 2) prev arrow does not work on first slide? 3) i have four slides in the script but only three are appearing?
I have your version of the slideshow embedded on the News & Media page (for testing) at chscottenterprises.com.
Any help would be appreciated.
I can not find a way to make both the images and caption resize.
Thanks
I tried to run this slide show from database while I replaced the "first" to "last" and "next" to "Prev". All sildes worked but captions do not display. Can anybody help me with running the same above slide show from last to first please?
Also had it clear and reset the Interval at the end of the gallery() function. Those fixes made it work perfectly for me.
You can see it under the about tab here:
http;//www.mappedgraphics.com/