책 목록 슬라이드

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

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,919
14년 전 조회 1,853
14년 전 조회 1,908
14년 전 조회 2,233
14년 전 조회 2,273
14년 전 조회 2,044
14년 전 조회 1,792
14년 전 조회 2,069
14년 전 조회 2,036
14년 전 조회 1,956
14년 전 조회 2,082
14년 전 조회 1,968
14년 전 조회 2,261
14년 전 조회 2,029
14년 전 조회 2,165
14년 전 조회 2,695
14년 전 조회 1,640
14년 전 조회 3,890
14년 전 조회 1,587
14년 전 조회 1,850
14년 전 조회 1,597
14년 전 조회 2,006
14년 전 조회 1,939
14년 전 조회 2,214
14년 전 조회 1,698
14년 전 조회 2,754
14년 전 조회 2,439
14년 전 조회 2,016
14년 전 조회 7,715
14년 전 조회 1,617
14년 전 조회 1,982
14년 전 조회 1,736
14년 전 조회 1,891
14년 전 조회 2,254
14년 전 조회 1,752
14년 전 조회 2,121
14년 전 조회 1,695
14년 전 조회 1,666
14년 전 조회 2,259
14년 전 조회 4,141
14년 전 조회 1,707
14년 전 조회 3,121
14년 전 조회 1,902
14년 전 조회 1,797
14년 전 조회 2,667
14년 전 조회 2,611
14년 전 조회 1,576
14년 전 조회 2,488
14년 전 조회 2,936
14년 전 조회 2,362
14년 전 조회 1,587
14년 전 조회 2,991
14년 전 조회 1,783
14년 전 조회 1,566
14년 전 조회 1,537
14년 전 조회 2,259
14년 전 조회 2,632
14년 전 조회 2,125
14년 전 조회 1,599
14년 전 조회 1,781
14년 전 조회 2,297
14년 전 조회 2,244
14년 전 조회 1,572
14년 전 조회 4,341
14년 전 조회 2,259
14년 전 조회 5,433
14년 전 조회 1,799
14년 전 조회 2,811
14년 전 조회 1,872
14년 전 조회 1,761
14년 전 조회 2,641
14년 전 조회 1,654
14년 전 조회 2,612
14년 전 조회 1,716
14년 전 조회 2,425
14년 전 조회 2,001
14년 전 조회 5,010
14년 전 조회 2,987
14년 전 조회 1,828
14년 전 조회 1,734
14년 전 조회 2,267
14년 전 조회 1,934
14년 전 조회 1,977
14년 전 조회 3,152
14년 전 조회 1,701
14년 전 조회 3,901
14년 전 조회 3,783
14년 전 조회 2,134
14년 전 조회 1,827
14년 전 조회 3,234
14년 전 조회 1,954
14년 전 조회 2,180
14년 전 조회 1,615
14년 전 조회 2,724
14년 전 조회 2,131
14년 전 조회 2,214
14년 전 조회 2,495
14년 전 조회 1,638
14년 전 조회 4,707
14년 전 조회 1,887