책 목록 슬라이드

이 글에서 문의한 내용에 맞도록 작성했습니다.

jQuery.animate에서 step을 이용하는 부분이 핵심(?)이고,

jQuery UI Effect의 Easing을 바꿔서 실험해보시면 다양한 경험이 가능합니다.



[index.html]

<!DOCTYPE html>
<head>
<title>Book Scroller</title>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<link href="stylesheet.less" media="screen" rel="stylesheet" type="text/less" />
<script src="http://code.jquery.com/jquery-1.7.1.js" type="text/javascript"></script>
<script src="http://jqueryui.com/ui/jquery.effects.core.js" type="text/javascript"></script>
<script src="http://lesscss.org/js/less.js" type="text/javascript"></script>
<script src="http://jashkenas.github.com/coffee-script/extras/coffee-script.js" type="text/javascript"></script>
<script src="application.coffee" type="text/coffeescript"></script>
</head>
<body>
<section id="content">
<div id="books">
<ul>
<li><img src="http://cfile3.uf.tistory.com/image/197A43364E6022C04F44D9" alt="Book #6" /></li>
<li><img src="http://cfile4.uf.tistory.com/image/14272C394E6022E1247E60" alt="Book #7" /></li>
<li><img src="http://cfile7.uf.tistory.com/image/1208654B4E0AB1DF1B8309" alt="Book #9" /></li>
<li><img src="http://cfile26.uf.tistory.com/image/1506AF474DF70B7E10AC86" alt="Book #12" /></li>
<li><img src="http://cfile29.uf.tistory.com/image/1506AF474DF70B7D0F3ABB" alt="Book #14" /></li>
</ul>
</div>
</section>
</body>
</html>


[stylesheet.less]

@itemWidth: 80px;
@itemHeight: 120px;
@linkWidth: 25px;
@linkHeight: 50px;

body {
font-size: 12px;
background: #EEE;
color: #333;
margin: 0;
}

#content {
margin: 10px auto;
padding: 20px;
width: 600px;
background: #FFF;
}

#books {
position: relative;
border: 2px solid #CCC;

ul {
margin: 0;
padding: 0;
list-style-type: none;
overflow: hidden;
}

li {
float: left;
margin: 5px;
width: @itemWidth;
height: @itemHeight;
border: 1px solid #EEE;

img {
width: @itemWidth;
height: @itemHeight;
}
}

a.previous,
a.next {
position: absolute;
top: (@itemHeight - @linkHeight) / 2;
display: block;
width: @linkWidth;
height: @linkHeight;
background-repeat: no-repeat;
overflow: hidden;
text-indent: -10000.0em;
}

a.previous {
left: 0;
background-position: 0 0;

&:hover {
background-position: 0 -@linkHeight;
}
}

a.next {
right: 0;
background-position: -@linkWidth 0;

&:hover {
background-position: -@linkWidth -@linkHeight;
}
}
}


[application.coffee]

jQuery.fn.bookScroller = (options) ->
  showCount = options.showCount
  scrollCount = options.scrollCount
  duration = options.duration

  container = $(this)
  list = container.find('ul')
  items = list.find('li')

  firstItem = list.find('li:first')
  itemWidth = firstItem.outerWidth(true)
  itemHeight = firstItem.outerHeight(true)

  step = (now, fx) ->
    item = $(fx.elem)
    if now <= -itemWidth
      fx.now += items.length * itemWidth
    if now >= (items.length - 1) * itemWidth
      fx.now -= items.length * itemWidth

  prevLink = $('<a></a>').attr(href: '#').text('Previous').addClass('previous')
    .click ->
      list.find('li').animate
        left: "+=#{itemWidth * scrollCount}px"
      ,
        duration: duration
        easing: 'easeOutBounce'
        step: step
      false

  nextLink = $('<a></a>').attr(href: '#').text('Next').addClass('next')
    .click ->
      list.find('li').animate
        left: "-=#{itemWidth * scrollCount}px"
      ,
        duration: duration
        easing: 'easeOutBounce'
        step: step
      false

  container
    .append(prevLink)
    .append(nextLink)
    .css
      overflow: 'hidden'
      width: showCount * itemWidth
      height: itemHeight
      paddingLeft: prevLink.outerWidth()
      paddingRight: nextLink.outerWidth()

  list.css
    position: 'relative'
    overflow: 'hidden'
    width: showCount * itemWidth
    height: itemHeight

  items.each (i, item) ->
    $(item).css
      position: 'absolute'
      top: 0
      left: i * itemWidth

$ ->
  $('#books').bookScroller
    showCount: 5
    scrollCount: 5
    duration: 800




|

댓글 2개

우어어어어어!! 멋지십니다 ㅠㅠ
유용할것 같습니다.
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 1,976
14년 전 조회 1,914
14년 전 조회 1,966
14년 전 조회 2,294
14년 전 조회 2,323
14년 전 조회 2,106
14년 전 조회 1,865
14년 전 조회 2,124
14년 전 조회 2,091
14년 전 조회 2,017
14년 전 조회 2,158
14년 전 조회 2,032
14년 전 조회 2,316
14년 전 조회 2,094
14년 전 조회 2,227
14년 전 조회 2,743
14년 전 조회 1,695
14년 전 조회 3,918
14년 전 조회 1,621
14년 전 조회 1,911
14년 전 조회 1,645
14년 전 조회 2,061
14년 전 조회 1,992
14년 전 조회 2,254
14년 전 조회 1,756
14년 전 조회 2,783
14년 전 조회 2,501
14년 전 조회 2,055
14년 전 조회 7,776
14년 전 조회 1,663
14년 전 조회 2,023
14년 전 조회 1,786
14년 전 조회 1,931
14년 전 조회 2,311
14년 전 조회 1,778
14년 전 조회 2,159
14년 전 조회 1,745
14년 전 조회 1,708
14년 전 조회 2,326
14년 전 조회 4,201
14년 전 조회 1,762
14년 전 조회 3,183
14년 전 조회 1,962
14년 전 조회 1,854
14년 전 조회 2,750
14년 전 조회 2,663
14년 전 조회 1,632
14년 전 조회 2,553
14년 전 조회 3,009
14년 전 조회 2,416
14년 전 조회 1,650
14년 전 조회 3,048
14년 전 조회 1,854
14년 전 조회 1,634
14년 전 조회 1,595
14년 전 조회 2,314
14년 전 조회 2,689
14년 전 조회 2,189
14년 전 조회 1,663
14년 전 조회 1,830
14년 전 조회 2,345
14년 전 조회 2,315
14년 전 조회 1,624
14년 전 조회 4,389
14년 전 조회 2,303
14년 전 조회 5,480
14년 전 조회 1,856
14년 전 조회 2,858
14년 전 조회 1,926
14년 전 조회 1,816
14년 전 조회 2,683
14년 전 조회 1,718
14년 전 조회 2,668
14년 전 조회 1,765
14년 전 조회 2,462
14년 전 조회 2,057
14년 전 조회 5,039
14년 전 조회 3,020
14년 전 조회 1,869
14년 전 조회 1,790
14년 전 조회 2,298
14년 전 조회 1,991
14년 전 조회 2,008
14년 전 조회 3,206
14년 전 조회 1,731
14년 전 조회 3,950
14년 전 조회 3,815
14년 전 조회 2,185
14년 전 조회 1,865
14년 전 조회 3,265
14년 전 조회 2,007
14년 전 조회 2,241
14년 전 조회 1,649
14년 전 조회 2,753
14년 전 조회 2,197
14년 전 조회 2,265
14년 전 조회 2,556
14년 전 조회 1,683
14년 전 조회 4,766
14년 전 조회 1,926