2

有一个很棒的小旋转木马滑块。next-slide/prev-slide问题是,只有当它们所在的 div 位于标记中的滑块内容 div 下方时,这些控件似乎才起作用。我希望这些控件位于滑块内容之上,有点像这样——

<h4>Slider</h4><div id="controls" style="float:right;">prev | next</div>
<div id="slider content">
  <ul>
    <li></li>
  </ul>
</div>

现在只有当我将控件 div 放在滑块内容 div 下时它才会起作用。

现在,我可以使用 CSS 将控件相对定位在页面上并将它们推到滑块内容上方,即使它们在标记中位于滑块内容下方,但这是一个问题,因为它在不同的浏览器中产生了很多松散的差异,因为其中的滑块内容ul非常流畅。我只想将控件浮动在与 h4 相同的行上,而不必使用相对定位等使整个控件 div 跳过滑块 div。

有没有办法将控件从滑块的“主体”中分离出来,以便它可以在我放置控件 div 的任何地方工作?

(function( $ ){

var _css = {};

var methods = {
    //
    // Initialize plugin
    //
    init : function( options ){

        var options = $.extend( {}, $.fn.lemmonSlider.defaults, options );

        return this.each(function(){

            var $slider = $( this ),
                data = $slider.data( 'slider' );

            if ( ! data ){

                var $sliderContainer = $slider.find( options.slider ),
                    $sliderControls = $slider.next().filter( '.controls' ),
                    $items = $sliderContainer.find( options.items ),
                    originalWidth = 1;

                $items.each(function(){ originalWidth += $( this ).outerWidth( true ) });
                $sliderContainer.width( originalWidth );

                // slide to last item
                if ( options.slideToLast ) $sliderContainer.css( 'padding-right', $slider.width() );

                // infinite carousel
                if ( options.infinite ){

                    originalWidth = originalWidth * 3;
                    $sliderContainer.width( originalWidth );

                    $items.clone().addClass( '-after' ).insertAfter( $items.filter(':last') );
                    $items.filter( ':first' ).before( $items.clone().addClass('-before') );

                    $items = $sliderContainer.find( options.items );

                }

                $slider.items = $items;
                $slider.options = options;

                // first item
                //$items.filter( ':first' ).addClass( 'active' );

                // attach events
                $slider.bind( 'nextSlide', function( e, t ){

                    var scroll = $slider.scrollLeft();
                    var x = 0;
                    var slide = 0;

                    $items.each(function( i ){
                        if ( x == 0 && $( this ).position().left > 1 ){
                            x = $( this ).position().left;
                            slide = i;
                        }
                    });

                    if ( x > 0 && $sliderContainer.outerWidth() - scroll - $slider.width() > 0 ){
                        slideTo( e, $slider, scroll+x, slide, 'fast' );
                    } else if ( options.loop ){
                        // return to first
                        slideTo( e, $slider, 0, 0, 'slow' );
                    }

                });
                $slider.bind( 'prevSlide', function( e, t ){

                    var scroll = $slider.scrollLeft();
                    var x = 0;
                    var slide = 0;

                    $items.each(function( i ){
                        if ( $( this ).position().left < 0 ){
                            x = $( this ).position().left;
                            slide = i;
                        }
                    });

                    if ( x ){
                        slideTo( e, $slider, scroll+x, slide, 'fast' )
                    } else if ( options.loop ){
                        // return to last
                        var a = $sliderContainer.outerWidth() - $slider.width();
                        var b = $items.filter( ':last' ).position().left;
                        slide = $items.size() - 1;
                        if ( a > b ){
                            slideTo( e, $slider, b, slide, 'fast' );
                        } else {
                            slideTo( e, $slider, a, slide, 'fast' );
                        }
                    }

                });
                $slider.bind( 'nextPage', function( e, t ){

                    var scroll = $slider.scrollLeft();
                    var w = $slider.width();
                    var x = 0;
                    var slide = 0;

                    $items.each(function( i ){
                        if ( $( this ).position().left < w ){
                            x = $( this ).position().left;
                            slide = i;
                        }
                    });

                    if ( x > 0 && scroll + w < originalWidth ){
                        slideTo( e, $slider, scroll+x, slide, 'slow' );
                    } else if ( options.loop ){
                        // return to first
                        slideTo( e, $slider, 0, 0, 'slow' );
                    }

                });
                $slider.bind( 'prevPage', function( e, t ){

                    var scroll = $slider.scrollLeft();
                    var w = $slider.width();
                    var x = 0;

                    $items.each(function( i ){
                        if ( $( this ).position().left < 1 - w ){
                            x = $( this ).next().position().left;
                            slide = i;
                        }
                    });

                    if ( scroll ){
                        if ( x == 0 ){
                            //$slider.animate({ 'scrollLeft' : 0 }, 'slow' );
                            slideTo( e, $slider, 0, 0, 'slow' );
                        } else {
                            //$slider.animate({ 'scrollLeft' : scroll + x }, 'slow' );
                            slideTo( e, $slider, scroll+x, slide, 'slow' );
                        }
                    } else if ( options.loop ) {
                        // return to last
                        var a = $sliderContainer.outerWidth() - $slider.width();
                        var b = $items.filter( ':last' ).position().left;
                        if ( a > b ){
                            $slider.animate({ 'scrollLeft' : b }, 'slow' );
                        } else {
                            $slider.animate({ 'scrollLeft' : a }, 'slow' );
                        }
                    }

                });
                $slider.bind( 'slideTo', function( e, i, t ){

                    slideTo(
                        e, $slider,
                        $slider.scrollLeft() + $items.filter( ':eq(' + i +')' ).position().left,
                        i, t );

                });

                // controls
                $sliderControls.find( '.next-slide' ).click(function(){
                    $slider.trigger( 'nextSlide' );
                    return false;
                });
                $sliderControls.find( '.prev-slide' ).click(function(){
                    $slider.trigger( 'prevSlide' );
                    return false;
                });
                $sliderControls.find( '.next-page' ).click(function(){
                    $slider.trigger( 'nextPage' );
                    return false;
                });
                $sliderControls.find( '.prev-page' ).click(function(){
                    $slider.trigger( 'prevPage' );
                    return false;
                });

                //if ( typeof $slider.options.create == 'function' ) $slider.options.create();

                $slider.data( 'slider', {
                    'target'  : $slider,
                    'options' : options
                })

            }

        });

    },
    //
    // Destroy plugin
    //
    destroy : function(){

        return this.each(function(){

            var $slider = $( this ),
                $sliderControls = $slider.next().filter( '.controls' ),
                data = $slider.data( 'slider' );

            $slider.unbind( 'nextSlide' );
            $slider.unbind( 'prevSlide' );
            $slider.unbind( 'nextPage' );
            $slider.unbind( 'prevPage' );
            $slider.unbind( 'slideTo' );

            $sliderControls.find( '.next-slide' ).unbind( 'click' );
            $sliderControls.find( '.prev-slide' ).unbind( 'click' );
            $sliderControls.find( '.next-page' ).unbind( 'click' );
            $sliderControls.find( '.next-page' ).unbind( 'click' );

            $slider.removeData( 'slider' );

        });

    }
    //
    //
    //
}
//
// Private functions
//
function slideTo( e, $slider, x, i, t ){

    $slider.items.filter( 'li:eq(' + i + ')' ).addClass( 'active' ).siblings( '.active' ).removeClass( 'active' );

    if ( typeof t == 'undefined' ){
        t = 'fast';
    }
    if ( t ){
        $slider.animate({ 'scrollLeft' : x }, t, function(){
            checkInfinite( $slider );
        });
    } else {
        var time = 0;
        $slider.scrollLeft( x );
        checkInfinite( $slider );
    }

    //if ( typeof $slider.options.slide == 'function' ) $slider.options.slide( e, i, time );

}
function checkInfinite( $slider ){

    var $active = $slider.items.filter( '.active' );
    if ( $active.hasClass( '-before' ) ){

        var i = $active.prevAll().size();
        $active.removeClass( 'active' );
        $active = $slider.items.filter( ':not(.-before):eq(' + i + ')' ).addClass( 'active' );
        $slider.scrollLeft( $slider.scrollLeft() + $active.position().left );

    } else if ( $active.hasClass( '-after' ) ){

        var i = $active.prevAll( '.-after' ).size();
        $active.removeClass( 'active' );
        $active = $slider.items.filter( ':not(.-before):eq(' + i + ')' ).addClass( 'active' );
        $slider.scrollLeft( $slider.scrollLeft() + $active.position().left );

    }

}
//
// Debug
//
function debug( text ){
    $( '#debug span' ).text( text );
}
//
//
//
$.fn.lemmonSlider = function( method ){  

    if ( methods[method] ) {
        return methods[ method ].apply( this, Array.prototype.slice.call( arguments, 1 ));
    } else if ( typeof method === 'object' || !method ){
        return methods.init.apply( this, arguments );
    } else {
        $.error( 'Method ' +  method + ' does not exist on jQuery.lemmonSlider' );
    }

};
//
//
//
$.fn.lemmonSlider.defaults = {

    'items'       : '> *',
    'loop'        : true,
    'slideToLast' : false,
    'slider'      : '> *:first',
    // since 0.2
    'infinite'    : false

}

})( jQuery );
4

1 回答 1

0

似乎迫使您将控件移至底部的行是这一行:

$sliderControls = $slider.next().filter( '.controls' ),

那就是寻找紧跟在滑块元素之后的元素,然后在所述元素中寻找具有“控件”类的元素。

如果您希望控件直接位于滑块上方,您可以尝试将该行替换为:

$sliderControls = $slider.prev().filter( '.controls' ),
于 2012-12-08T21:08:31.517 回答