使用 Modulus 为 jquery 循环自定义分页器返回

发布于 2024-12-18 09:27:08 字数 1509 浏览 2 评论 0原文

尝试让这个自定义分页器适用于 jQuery Cycle。

我希望 pagerAnchorBuilder 每 5 个图像返回一个 list 项目,以便稍后我可以将寻呼机转变为它自己的循环。

代码如下:

  pagerAnchorBuilder: function(idx,slide){
        var $slideCount = $('#ul-homecycle > li').length; 
            if ((idx==0) || (idx%5 === 0)){
                return '<li><a href="javascript:setSlide('+ idx +')" class="transhover"><img src="../images/home/thumb_carousel' + idx + '.jpg" width="183" height="72" /></a></li>';
            }
            else{ 
                return '<a href="javascript:setSlide('+ idx +')" class="transhover"><img src="../images/home/thumb_carousel' + idx + '.jpg" width="183" height="72" /></a>';

            }
    }

所以最后我希望 Cycle 返回这样的内容:

<ul>
<li>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
</li>
<li>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
</li>
</ul>

请忽略 setSlide(#) 和 JS 中返回的 HTML 字符串中的类值,我已经控制住了。即使经过两个小时的搜索,我也无法弄清楚这一点。

提前致谢!

Trying to get this custom pager to work for jQuery Cycle.

I want the pagerAnchorBuilder to return a list item every 5 images so later on I can turn the pager into it's own cycle.

Here's the code:

  pagerAnchorBuilder: function(idx,slide){
        var $slideCount = $('#ul-homecycle > li').length; 
            if ((idx==0) || (idx%5 === 0)){
                return '<li><a href="javascript:setSlide('+ idx +')" class="transhover"><img src="../images/home/thumb_carousel' + idx + '.jpg" width="183" height="72" /></a></li>';
            }
            else{ 
                return '<a href="javascript:setSlide('+ idx +')" class="transhover"><img src="../images/home/thumb_carousel' + idx + '.jpg" width="183" height="72" /></a>';

            }
    }

So in the end I want Cycle to return this:

<ul>
<li>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
</li>
<li>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
<a href="javascript:void(0);">derp</a>
</li>
</ul>

Please disregard the setSlide(#) and the class values from the HTML string return in the JS, I have that under control. I can't figure this out even after 2 hours of searching.

Thanks in advance!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

や莫失莫忘 2024-12-25 09:27:08

我最终弄清楚了。这是修改后的代码,为了方便您进行了注释:

function cycles(){
    //Activate main slide with proper pager/carousel container.
    $('#ul-homecycle').after('<div id="homecycle-carousel-container"><a href="javascript:void(0);" id="btn-homecycle-prev" class="transhover"></a><a href="javascript:void(0);" id="btn-homecycle-next" class="transhover"></a><ul id="homecycle-carousel">').cycle({
        timeout: 7000,
        speed: 500,
        sync: true,
        fx: 'fade',
        fit: 0,
        startingSlide: 2,
        activePagerClass:'active',
        slideResize: 0,
        pager:  '#homecycle-carousel',
        pagerAnchorBuilder: function(idx,slide){
            return '<a href="javascript:setSlide('+ idx +')" class="transhover"><img src="../images/home/thumb_carousel' + idx + '.jpg" width="183" height="72" /></a>';
        },
        // Build pager that automagically hightlights updated pager thumb and also continue to next pager slide if the next thumb isn't visible
        updateActivePagerLink: function(pager, activeIndex) { 
            $(pager).find('a').not(':eq('+activeIndex+')').removeClass('active').children('img').fadeTo(200,.5)
            $(pager).find('a:eq('+activeIndex+')').addClass('active').children('img').fadeTo(200, 1); 

            //If next slide in carousel is hidden then go to next carousel slide
            if ($(pager).find('a:eq('+activeIndex+')').parent('li').css('display') == "none"){
                $('#homecycle-carousel').cycle('next');
            }
        }
    });
        //Before building the carousel wrap an Li around every 5 thumbs    
        $('#homecycle-carousel > a').each(function(i) {
           var a = $('#homecycle-carousel > a');
            for( var i = 0; i < a.length; i+=5 ) {
                a.slice(i, i+5).wrapAll('<li></li>');
            }
        });
        //Now that we have Lis wrapped around every 5 thumbs, initiate new cycle    
        $('#homecycle-carousel').cycle({
            easing: 'easeOutSine',
            prev: '#btn-homecycle-prev',
            next: '#btn-homecycle-next',
            slideExpr: 'li',
            activePagerClass:'active',
            timeout:0,
            speed: 500,
            fx: 'scrollHorz'
        });
        //Artifically activate new thumb 
        $('#homecycle-carousel li a').click(function(){
        if(!$(this).hasClass('active')){
            $('#homecycle-carousel li a').not(this).removeClass('active').children('img').fadeTo(200,.5);
            $(this).addClass('active').children('img').fadeTo(200,1);
        }
        });

}

I ended up figuring it out. Here's the modified code, commented for your convenience:

function cycles(){
    //Activate main slide with proper pager/carousel container.
    $('#ul-homecycle').after('<div id="homecycle-carousel-container"><a href="javascript:void(0);" id="btn-homecycle-prev" class="transhover"></a><a href="javascript:void(0);" id="btn-homecycle-next" class="transhover"></a><ul id="homecycle-carousel">').cycle({
        timeout: 7000,
        speed: 500,
        sync: true,
        fx: 'fade',
        fit: 0,
        startingSlide: 2,
        activePagerClass:'active',
        slideResize: 0,
        pager:  '#homecycle-carousel',
        pagerAnchorBuilder: function(idx,slide){
            return '<a href="javascript:setSlide('+ idx +')" class="transhover"><img src="../images/home/thumb_carousel' + idx + '.jpg" width="183" height="72" /></a>';
        },
        // Build pager that automagically hightlights updated pager thumb and also continue to next pager slide if the next thumb isn't visible
        updateActivePagerLink: function(pager, activeIndex) { 
            $(pager).find('a').not(':eq('+activeIndex+')').removeClass('active').children('img').fadeTo(200,.5)
            $(pager).find('a:eq('+activeIndex+')').addClass('active').children('img').fadeTo(200, 1); 

            //If next slide in carousel is hidden then go to next carousel slide
            if ($(pager).find('a:eq('+activeIndex+')').parent('li').css('display') == "none"){
                $('#homecycle-carousel').cycle('next');
            }
        }
    });
        //Before building the carousel wrap an Li around every 5 thumbs    
        $('#homecycle-carousel > a').each(function(i) {
           var a = $('#homecycle-carousel > a');
            for( var i = 0; i < a.length; i+=5 ) {
                a.slice(i, i+5).wrapAll('<li></li>');
            }
        });
        //Now that we have Lis wrapped around every 5 thumbs, initiate new cycle    
        $('#homecycle-carousel').cycle({
            easing: 'easeOutSine',
            prev: '#btn-homecycle-prev',
            next: '#btn-homecycle-next',
            slideExpr: 'li',
            activePagerClass:'active',
            timeout:0,
            speed: 500,
            fx: 'scrollHorz'
        });
        //Artifically activate new thumb 
        $('#homecycle-carousel li a').click(function(){
        if(!$(this).hasClass('active')){
            $('#homecycle-carousel li a').not(this).removeClass('active').children('img').fadeTo(200,.5);
            $(this).addClass('active').children('img').fadeTo(200,1);
        }
        });

}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文