JQuery Swiper滑动高度

时间:2016-12-14 22:49:26

标签: jquery css jquery-plugins swiper

我正在使用JQuery Swiper。我基本上有一个部分,我将高度设置为视口高度。

#portfolio {
  height: 100vh;
}

在此部分中,我有一个左侧和一个右侧,我设置为100%

#portfolio-left {
    background: #6bbea5 none repeat scroll 0 0;
    height: 100%;
}

#portfolio-right {
    height: 100%;
    padding: 0;
}

#portfolio-left只会保留一个小文字,而#portfolio-right会保留我的滑块。

所以我添加了我的滑块容器,以及我想要添加到滑块的内容。我然后设置了

$(function() {

     var swiperH = new Swiper('.swiper-container-h', {
        pagination: '.swiper-pagination-h',
        paginationClickable: true
    });
    var swiperV = new Swiper('.swiper-container-v', {
        pagination: '.swiper-pagination-v',
        paginationClickable: true,
        direction: 'vertical',
        freeMode: true,
        autoHeight: true,
        grabCursor: true
    });
});

它最终将是双向的,因此我有垂直和水平的原因。我已经垂直添加了两张幻灯片来演示我的问题。从本质上讲,第一张幻灯片有很多内容,并没有给出动态高度。我认为这与在投资组合上给予100%高度有关,但不太确定。我已经设置了JSFiddle来演示。

如何让幻灯片具有自动高度,同时让整个部分达到100vh?

这是我所追求的一个例子 Example

非常感谢

2 个答案:

答案 0 :(得分:5)

似乎JSFiddle可能在适应Swiper方面遇到一些麻烦。但这是一个fork of your fiddle。但是,它在XAMPP服务器上运行良好,我也将其移动到live site

  $(function() {
     var swiperH = new Swiper('.swiper-container-h', {
     pagination: '.swiper-pagination-h',
     paginationClickable: true,
     });

     var swiperV = new Swiper('.swiper-container-v', {
     pagination: '.swiper-pagination-v',
     paginationClickable: true,
     direction: 'vertical',
     freeMode: true,
     autoHeight: true,
     grabCursor: true,
     slidesPerView: 'auto'        
  });
});  

请注意添加“slidesPerView:'auto'”

最新版本的Swiper

    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/Swiper/3.4.1/css/swiper.min.css">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/Swiper/3.4.1/js/swiper.jquery.min.js"></script>

答案 1 :(得分:2)

伙计,考虑到HTML层次结构,我已经重构了CSS

看看您是否需要:JSFiddle

$(function() {
     var swiperH = new Swiper('.swiper-container-h', {
        pagination: '.swiper-pagination-h',
        paginationClickable: true
    });
    var swiperV = new Swiper('.swiper-container-v', {
        pagination: '.swiper-pagination-v',
        paginationClickable: true,
        direction: 'vertical',
        freeMode: true,
        autoHeight: true,
        grabCursor: true
    });
});
#portfolio {
  height: 100vh;
}

#portfolio-left {
  height: 100vh;
  background: #6bbea5 none repeat scroll 0 0;
}

#portfolio-right {
  height: 100vh;
  padding: 0;
}

.swiper-container {
  color: #000;
}

.swiper-wrapper {
  height: 100vh;
}

.swiper-slide {
  display: table;
}

.goldBG {
  background: #fabc2f;
}
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"/>
<link href="https://cdnjs.cloudflare.com/ajax/libs/Swiper/3.0.0/css/swiper.min.css" rel="stylesheet"/>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/Swiper/3.0.0/js/swiper.jquery.min.js"></script>

<section id="portfolio">
    <div class="col-lg-5 col-sm-5" id="portfolio-left">
        <div id="portfolio-title">
            <h2>Work</h2>
        </div>
    </div>

    <div class="col-lg-7 col-sm-7" id="portfolio-right">
        <div class="swiper-container swiper-container-h">
            <div class="swiper-wrapper">
                <div class="swiper-slide">
                    <div class="swiper-container swiper-container-v">
                        <div class="swiper-wrapper">
                            <div class="swiper-slide goldBG">
                                <div class="row addMargin">
                                    <div class="col-md-5 col-md-offset-1 vertical-center inner">
                                        <div class="content-holder-l">
                                            <p>French</p>
                                            <img src="https://placeholdit.imgix.net/~text?txtsize=28&txt=300%C3%97300&w=300&h=300">
                                        </div>
                                    </div>
                                </div>
                                <div class="row addMargin">
                                    <div class="col-md-5 col-md-offset-1 vertical-center inner">
                                        <div class="content-holder-l">
                                            <p>French</p>
                                            <img src="https://placeholdit.imgix.net/~text?txtsize=28&txt=300%C3%97300&w=300&h=300">
                                        </div>
                                    </div>
                                </div>
                                <div class="row addMargin">
                                    <div class="col-md-5 col-md-offset-1 vertical-center inner">
                                        <div class="content-holder-l">
                                            <p>French</p>
                                            <img src="https://placeholdit.imgix.net/~text?txtsize=28&txt=300%C3%97300&w=300&h=300">
                                        </div>
                                    </div>
                                </div>
                                <div class="row addMargin">
                                    <div class="col-md-5 col-md-offset-1 vertical-center inner">
                                        <div class="content-holder-l">
                                            <p>French</p>
                                            <img src="https://placeholdit.imgix.net/~text?txtsize=28&txt=300%C3%97300&w=300&h=300">
                                        </div>
                                    </div>
                                </div>
                            </div>
                            <div class="clearfix">
                            </div>
                            <div class="swiper-slide">
                                duyfghisdgfdshfsdygfuygdsufygsdgyudgsyfugsdyugf
                                <br> sdf
                                <br> sdfsdfsdfsd
                                <br> fsdfsdf sdfsdfsdf
                            </div>
                        </div>
                        <div class="swiper-pagination swiper-pagination-v"></div>
                    </div>
                </div>
                <div class="swiper-pagination swiper-pagination-h"></div>
            </div>
        </div>
    </div>
</section>