bootstrap 3多项目轮播

时间:2018-10-26 22:28:51

标签: jquery html css

我正在使用this code(改编自the original)在Bootstrap 3中创建一个多项目轮播。效果很好,但我不知道如何制作不同宽度的图块。我将图像放在那里,它们的高度相同,但宽度不同。

仅供参考,我尝试使用slick from Ken Wheeler,但无法使其与Bootstrap 3配合使用。

这是CSS

.MultiCarousel { float: left; overflow: hidden; padding: 15px; width: 100%; position:relative; }
    .MultiCarousel .MultiCarousel-inner { transition: 1s ease all; float: left; }
        .MultiCarousel .MultiCarousel-inner .item { float: left;}
        .MultiCarousel .MultiCarousel-inner .item > div { text-align: center; padding:10px; margin:10px; background:#f1f1f1; color:#666;}
    .MultiCarousel .leftLst, .MultiCarousel .rightLst { position:absolute; border-radius:50%;top:calc(50% - 20px); }
    .MultiCarousel .leftLst { left:0; }
    .MultiCarousel .rightLst { right:0; }

        .MultiCarousel .leftLst.over, .MultiCarousel .rightLst.over { pointer-events: none; background:#ccc; }

和HTML

<div class="container">
    <div class="row">
        <div class="MultiCarousel" data-items="1,3,5,6" data-slide="1" id="MultiCarousel"  data-interval="1000">
            <div class="MultiCarousel-inner">
                <div class="item">
                    <div class="pad15">
                         <img height=150 width=150 src="https://www.cheatsheet.com/wp-content/uploads/2017/06/sulky-cat.jpg"  />
                    </div>
                </div>
                <div class="item">
                    <div class="pad15">
                         <img height=150 width=250 src="https://i.guim.co.uk/img/static/sys-images/Guardian/Pix/pictures/2014/9/16/1410886254505/Stressed-cat-014.jpg?width=620&quality=85&auto=format&fit=max&s=4a1e1cc7d9c441d8c1253b439b7ac040"  />
                    </div>
                </div>
                <div class="item">
                    <div class="pad15">
                         <img height=150 width=350 src="https://www.cheatsheet.com/wp-content/uploads/2017/06/sulky-cat.jpg"  />
                    </div>
                </div>
                <div class="item">
                    <div class="pad15">
                         <img height=150 width=50 src="https://www.purina.co.uk/sites/g/files/mcldtz776/files/2017-11/How-old-is-my-cat-in-human-years_0.jpg"  />
                    </div>
                </div>
                <div class="item">
                    <div class="pad15">
                         <img height=150 src="https://www.cheatsheet.com/wp-content/uploads/2017/06/sulky-cat.jpg"  />
                    </div>
                </div>
                <div class="item">
                    <div class="pad15">
                         <img height=150 src="https://www.cheatsheet.com/wp-content/uploads/2017/06/sulky-cat.jpg"  />
                    </div>
                </div>
                <div class="item">
                    <div class="pad15">
                         <img height=150 src="https://www.cheatsheet.com/wp-content/uploads/2017/06/sulky-cat.jpg"  />
                    </div>
                </div>
                <div class="item">
                    <div class="pad15">
                         <img height=150 src="https://www.cheatsheet.com/wp-content/uploads/2017/06/sulky-cat.jpg"  />
                    </div>
                </div>
                <div class="item">
                    <div class="pad15">
                         <img height=150 src="https://www.cheatsheet.com/wp-content/uploads/2017/06/sulky-cat.jpg"  />
                    </div>
                </div>
            </div>
            <button class="btn btn-primary leftLst"><</button>
            <button class="btn btn-primary rightLst">></button>
        </div>
    </div>
    <div class="row">
        <div class="col-md-12 text-center">
            <br/><br/><br/>
            <hr/>
            <p>Settings</p>
            <p>Change data items for xs,sm,md and lg display items respectively. Ex:data-items="1,3,5,6"</p>
            <p>Change data slide for slides per click Ex:data-slide="1"</p>
        </div>
    </div>
</div>

和js

$(document).ready(function () {
    var itemsMainDiv = ('.MultiCarousel');
    var itemsDiv = ('.MultiCarousel-inner');
    var itemWidth = "";

    $('.leftLst, .rightLst').click(function () {
        var condition = $(this).hasClass("leftLst");
        if (condition)
            click(0, this);
        else
            click(1, this)
    });

    ResCarouselSize();




    $(window).resize(function () {
        ResCarouselSize();
    });

    //this function define the size of the items
    function ResCarouselSize() {
        var incno = 0;
        var dataItems = ("data-items");
        var itemClass = ('.item');
        var id = 0;
        var btnParentSb = '';
        var itemsSplit = '';
        var sampwidth = $(itemsMainDiv).width();
        var bodyWidth = $('body').width();
        $(itemsDiv).each(function () {
            id = id + 1;
            var itemNumbers = $(this).find(itemClass).length;
            btnParentSb = $(this).parent().attr(dataItems);
            itemsSplit = btnParentSb.split(',');
            $(this).parent().attr("id", "MultiCarousel" + id);


            if (bodyWidth >= 1200) {
                incno = itemsSplit[3];
                itemWidth = sampwidth / incno;
            }
            else if (bodyWidth >= 992) {
                incno = itemsSplit[2];
                itemWidth = sampwidth / incno;
            }
            else if (bodyWidth >= 768) {
                incno = itemsSplit[1];
                itemWidth = sampwidth / incno;
            }
            else {
                incno = itemsSplit[0];
                itemWidth = sampwidth / incno;
            }
            $(this).css({ 'transform': 'translateX(0px)', 'width': itemWidth * itemNumbers });
            $(this).find(itemClass).each(function () {
                $(this).outerWidth(itemWidth);
            });

            $(".leftLst").addClass("over");
            $(".rightLst").removeClass("over");

        });
    }


    //this function used to move the items
    function ResCarousel(e, el, s) {
        var leftBtn = ('.leftLst');
        var rightBtn = ('.rightLst');
        var translateXval = '';
        var divStyle = $(el + ' ' + itemsDiv).css('transform');
        var values = divStyle.match(/-?[\d\.]+/g);
        var xds = Math.abs(values[4]);
        if (e == 0) {
            translateXval = parseInt(xds) - parseInt(itemWidth * s);
            $(el + ' ' + rightBtn).removeClass("over");

            if (translateXval <= itemWidth / 2) {
                translateXval = 0;
                $(el + ' ' + leftBtn).addClass("over");
            }
        }
        else if (e == 1) {
            var itemsCondition = $(el).find(itemsDiv).width() - $(el).width();
            translateXval = parseInt(xds) + parseInt(itemWidth * s);
            $(el + ' ' + leftBtn).removeClass("over");

            if (translateXval >= itemsCondition - itemWidth / 2) {
                translateXval = itemsCondition;
                $(el + ' ' + rightBtn).addClass("over");
            }
        }
        $(el + ' ' + itemsDiv).css('transform', 'translateX(' + -translateXval + 'px)');
    }

    //It is used to get some elements from btn
    function click(ell, ee) {
        var Parent = "#" + $(ee).parent().attr("id");
        var slide = $(Parent).attr("data-slide");
        ResCarousel(ell, Parent, slide);
    }

});

0 个答案:

没有答案