あなたはCSSを含む全体のことを求めているので、ここでの作業のデモは、(だが、このようなクロム、SafariなどCSS3トランジション対応ブラウザが必要ですまたはFirefox 4以降):http://jsfiddle.net/jfriend00/cwP5Q/。
HTML:
<div id="container">
<img id="slideimg0" class="slide showMe" src="http://photos.smugmug.com/photos/344287800_YL8Ha-S.jpg">
<img id="slideimg1" class="slide" src="http://photos.smugmug.com/photos/344287888_q22cB-S.jpg">
<img id="slideimg2" class="slide" src="http://photos.smugmug.com/photos/344284440_68L2K-S.jpg">
<img id="slideimg3" class="slide" src="http://photos.smugmug.com/photos/344286315_oyxRy-S.jpg">
<img id="slideimg4" class="slide" src="http://photos.smugmug.com/photos/344285236_hjizX-S.jpg">
</div>
はCSS:
#container {position: relative; font-size: 0;}
.slide {
border: none;
opacity: 0;
position: absolute;
top: 0;
left: 0;
-webkit-transition: opacity 2s linear;
-moz-transition: opacity 2s linear;
-o-transition: opacity 2s linear;
transition: opacity 2s linear;
}
.showMe {opacity: 1;}
JS(実行ページは準備ができている):
var timer = setInterval(nextImage, 4000);
var curImage = 0;
var numImages = 5;
function nextImage() {
var e;
// remove showMe class from current image
e = document.getElementById("slideimg" + curImage);
removeClass(e, "showMe");
// compute next image
curImage++;
if (curImage > numImages - 1) {
curImage = 0;
}
// add showMe class to next image
e = document.getElementById("slideimg" + curImage);
addClass(e, "showMe");
}
function addClass(elem, name) {
var c = elem.className;
if (c) c += " "; // if not blank, add a space separator
c += name;
elem.className = c;
}
function removeClass(elem, name) {
var c = elem.className;
elem.className = c.replace(name, "").replace(/ /g, " ").replace(/^ | $/g, ""); // remove name and extra blanks
}
あなたが本当のためにこれをやろうとしていた場合、あなたがすべきjQueryやYUIのようなクラスライブラリを使うと、CSS3対応のブラウザだけでなく、すべてのブラウザで簡単にアニメーションを作成できます。
私はあなたの別のJavascriptを試しましたが、それは私のためには機能しませんでした(画像は切り替わらなかった)。私が言ったように、私はJavascriptを初めて使っているので、それは私のせいだと驚かないだろう。私は現在、どのようにそれを統合するのか分からなかったので、このためのCSSはありません。 – Christopher
CSSを含めた全体的な作業例を求めているように聞こえてきたので、私はその答えを変えました。 – jfriend00