我正在使用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?
非常感谢
答案 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>