JQuery Вращающийся Баннер Вопрос - PullRequest
3 голосов
/ 13 января 2010

Я ищу решение JQuery для чего-то вроде вращающегося баннера, расположенного по адресу http://www.bazaarvoice.com.

Тот, у которого есть прокрутка по времени, но также позволяет пользователю переключаться с помощью пролистывания вкладок. Кто-нибудь знает хороший, легкий стиль?

1 Ответ

8 голосов
/ 14 января 2010

Используйте плагин Cycle Lite для jQuery. Он имеет небольшой размер и все необходимые функции:

Смотрите более продвинутые демонстрации прямо здесь .

Редактировать: вот пример кода для вас:
Вам понадобится плагин Cycle , а не плагин Cycle Lite.
HTML:

<div id="slideshow">
    <ul class="pager">
        <!-- will be populated with thumbs by JS -->
    </ul>
    <!-- each div is considered as a slide show -->
    <div><img src="/images/banner1.png" />You can place text here too !</div>
    <div><img src="/images/banner2.png" /></div>
    <div><img src="/images/banner3.png" /></div>
</div>

CSS:

.thumb.selected {
    border: 2px gray solid;
}

ul.pager li {
    list-style: none;
    float: left;
    width: 200px;
    height: 80px;
    background-color: #eee;
}

#slideshow > div {
    background-color: #eee;
    border: 1px solid #ddd;
}

Javascript:

$("#slideshow").cycle({ 
    fx:           'fade',  // name of transition effect (or comma separated names, ex: fade,scrollUp,shuffle) 
    timeout:       1000,   // milliseconds between slide transitions (0 to disable auto advance) 
    speed:         400,    // speed of the transition (any valid fx speed value) 
    pager:         "#tabs",// selector for element to use as pager container 
    pagerClick:    null,  // callback fn for pager clicks:  function(zeroBasedSlideIndex, slideElement) 
    pagerEvent:   'hover',// name of event which drives the pager navigation 
    pagerAnchorBuilder: function(i, slide){// callback fn for building anchor links:  function(index, DOMelement) 
        return '<li class="thumb" id="thumb-1"><img src="' + slide.src + '" height="30" width="40" /></a></li>';
    },
    before: function(){ // deselect all slides
        $(".thumb").removeClass('selected');
    },
    after: function(foo, bar, opts){ // select current slide
        $("#thumb-"+opts.currSlide).addClass('selected');
    }, 
    fit:           1,     // force slides to fit container 
    pause:         1,     // true to enable "pause on hover" 
    pauseOnPagerHover: 1, // stop slideshow when pagers are being hovered
    autostop:      0,     // true to end slideshow after X transitions (where X == slide count) 
    autostopCount: 0,     // number of transitions (optionally used with autostop to define X)  
    slideExpr:     "div", // all content of div#slider is a slide. but not the pager
    fastOnEvent:   100,   // force fast transitions when triggered manually (via pager or prev/next); value == time in ms 
});

Наслаждайтесь, это не проверено, но должно работать.

Edit2:
Замените параметр pagerAnchorBuilder на return '<li class="thumb" id="thumb-1"><img src="' + slide.src + '" /></a></li>';

Полагаю, вы хотите изменить ширину и / или высоту. Просто удалите высоту HTML и используйте свойство CSS: .thumb img { height: 10px; width: 10px; } Вы также можете добавить некоторые пользовательские свойства CSS.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...