我已经使用URLhashListener
事件创建水平页面滑动。
当我们单击页面1的页面3按钮时,幻灯片应直接滚动到页面3。现在它滑过页面2。
从第1页转到第3页时,如何隐藏第二页。
看我的代码:
$('.owl-carousel').owlCarousel({
items: 1,
autoplay: false,
loop: false,
nav: false,
dots: false,
center: true,
mouseDrag: false,
touchDrag: false,
autoHeight: true,
margin: 10,
smartSpeed: 500,
URLhashListener: true,
autoplayHoverPause: true,
startPosition: 'URLHash'
});
.owl-carousel {
position: relative;
}
.page {
height: 10rem;
padding: 1rem;
height: 200px;
}
.one {
background: #bec4bd;
}
.two {
background: green;
}
.three {
background: #41253c;
}
.linkA {
position: absolute;
bottom: 10px;
left: 10px;
text-decoration: none;
background: red;
color: #fff;
padding: 5px 15px;
margin-right: 5px;
font-family: sans-serif;
font-size: 14px;
}
.linkB {
position: absolute;
bottom: 10px;
right: 10px;
text-decoration: none;
background: red;
color: #fff;
padding: 5px 15px;
margin-right: 5px;
font-family: sans-serif;
font-size: 14px;
}
<link href="https://owlcarousel2.github.io/OwlCarousel2/assets/owlcarousel/assets/owl.carousel.min.css" rel="stylesheet" />
<link href="https://owlcarousel2.github.io/OwlCarousel2/assets/owlcarousel/assets/owl.theme.default.min.css" rel="stylesheet" />
<script src="https://owlcarousel2.github.io/OwlCarousel2/assets/vendors/jquery.min.js"></script>
<script src="https://owlcarousel2.github.io/OwlCarousel2/assets/owlcarousel/owl.carousel.js"></script>
<div class="owl-carousel owl-theme">
<div class="page one" data-hash="page1">
Button at the bottom!
<a href="#page2" class="linkA">Page 2</a>
<a href="#page3" class="linkB">Page 3</a>
</div>
<div class="page two" data-hash="page2">
Button at the bottom!
<a href="#page1" class="linkA">Page 1</a>
<a href="#page3" class="linkB">Page 3</a>
</div>
<div class="page three" data-hash="page3" style="color:#fff;">
Button at the bottom!
<a href="#page2" class="linkA">Page 2</a>
</div>
</div>
最佳答案
我设法通过以下方式删除了该项目:
在第3页的第1页的按钮中添加onclick="hidePage2();"
添加hidePage2()
函数(请参见下文)。
但是,第2页在删除(duh)后会被删除,但是当尝试使用“附加”功能或类似功能恢复时,它会出现故障。不过,在这里,我谦虚地提出了以下建议:
$('.owl-carousel').owlCarousel({
items: 1,
autoplay: false,
loop: false,
nav: false,
dots: false,
center: true,
mouseDrag: false,
touchDrag: false,
autoHeight: true,
margin: 10,
smartSpeed: 500,
URLhashListener: true,
autoplayHoverPause: true,
startPosition: 'URLHash'
});
function hidePage2(){
// from https://stackoverflow.com/a/39543557/13023528
var indexToRemove = 1;
$('.owl-carousel').owlCarousel('remove', indexToRemove).owlCarousel('update');
}
.owl-carousel {
position: relative;
}
.page {
height: 10rem;
padding: 1rem;
height: 200px;
}
.one {
background: #bec4bd;
}
.two {
background: green;
}
.three {
background: #41253c;
}
.linkA {
position: absolute;
bottom: 10px;
left: 10px;
text-decoration: none;
background: red;
color: #fff;
padding: 5px 15px;
margin-right: 5px;
font-family: sans-serif;
font-size: 14px;
}
.linkB {
position: absolute;
bottom: 10px;
right: 10px;
text-decoration: none;
background: red;
color: #fff;
padding: 5px 15px;
margin-right: 5px;
font-family: sans-serif;
font-size: 14px;
}
<link href="https://owlcarousel2.github.io/OwlCarousel2/assets/owlcarousel/assets/owl.carousel.min.css" rel="stylesheet" />
<link href="https://owlcarousel2.github.io/OwlCarousel2/assets/owlcarousel/assets/owl.theme.default.min.css" rel="stylesheet" />
<script src="https://owlcarousel2.github.io/OwlCarousel2/assets/vendors/jquery.min.js"></script>
<script src="https://owlcarousel2.github.io/OwlCarousel2/assets/owlcarousel/owl.carousel.js"></script>
<div id="owlCarousel" class="owl-carousel owl-theme">
<div class="page one" data-hash="page1">
Button at the bottom!
<a href="#page2" class="linkA">Page 2</a>
<a href="#page3" onclick="hidePage2();" class="linkB">Page 3</a>
</div>
<div class="page two" data-hash="page2">
Button at the bottom!
<a href="#page1" class="linkA">Page 1</a>
<a href="#page3" class="linkB">Page 3</a>
</div>
<div class="page three" data-hash="page3" style="color:#fff;">
Button at the bottom!
<a href="#page2" class="linkA">Page 2</a>
</div>
</div>
编辑:哎呀错别字