jQueryを使ったイメージスクローラーのチュートリアル[js]

Nettuts+より、jQueryを使ったイメージスクローラーのチュートリアルの紹介です。

デモページはコチラから

jq0904241.jpg

以下がマーアクアップです。チュートリアルと言っても、ごく普通に下記のようにマーアクアップして、jQueryとjsファイルを設置すれば大丈夫です。

HTML

<div id="outerContainer">
      <div id="imageScroller">
	  <div id="viewer" class="js-disabled">
	    <a class="wrapper" href="http://www.apple.com" title="Apple"><img class="logo" id="apple" src="logos/apple.jpg" alt="Apple">
	    <a class="wrapper" href="http://mozilla-europe.org/en/firefox" title="Firefox"><img class="logo" id="firefox" src="logos/firefox.jpg" alt="Firefox">
	    <a class="wrapper" href="http://jquery.com" title="jQuery"><img class="logo" id="jquery" src="logos/jquery.jpg" alt="jQuery">
	    <a class="wrapper" href="http://twitter.com" title="Twitter"><img class="logo" id="twitter" src="logos/twitter.jpg" alt="Twitter">
	    <a class="wrapper" href="http://jqueryui.com" title="jQuery UI"><img class="logo" id="jqueryui" src="logos/jqueryui.jpg" alt="jQuery UI">
	  </div>
      </div>
    </div>

CSS

.js-disabled img { width:100px; height:100px; display:block; float:left; margin:30px 0 0; }

#outerContainer { width:542px; height:202px; margin:auto; position:relative; }
#imageScroller { width:542px; height:202px; position:relative; background:#000000 url(images/imageScrollerBG.png) no-repeat; }
#viewer { width:522px; height:182px; overflow:hidden; margin:auto; position:relative; top:10px; }
#imageScroller a:active, #imageScroller a:visited { color:#000000; }
#imageScroller a img { border:0; }
#controls { width:534px; height:47px; background:url(images/controlsBG.png) no-repeat; position:absolute; top:4px; left:4px; z-index:10;	}
#controls a { width:37px; height:35px; position:absolute; top:3px; }
#controls a:active, #controls a:visited { color:#0d0d0d; }
#title { color:#ffffff; font-family:arial; font-size:100%; font-weight:bold; width:100%; text-align:center; margin-top:10px; }
#rtl { background:url(images/rtl.png) no-repeat; left:100px; }
#rtl:hover { background:url(images/rtl_over.png) no-repeat; left:99px; }
#ltr { background:url(images/ltr.png) no-repeat; right:100px; }
#ltr:hover { background:url(images/ltr_over.png) no-repeat; }

jQuery

$("#viewer").removeClass("js-disabled");
			
$("<div>").attr("id", "container").css({ 
  position:"absolute"
}).width($(".wrapper").length * 170).height(170).appendTo("div#viewer");
			  	
$(".wrapper").each(function() {
  $(this).appendTo("div#container");
});
				
var duration = $(".wrapper").length * 1000;
				
var speed = (parseInt($("div#container").width()) + parseInt($("div#viewer").width())) / duration;
								
var direction = "rtl";
				
(direction == "rtl") ? $("div#container").css("left", $("div#viewer").width()).addClass("rtl") : $("div#container").css("left", 0 - $("div#container").width()).addClass("ltr") ;