轮播效果
一个幻灯片组件,用于在元素、图像或文本幻灯片(如轮播图)之间循环更新于: 2023-04-30 14:28:21 查看: 535
发布于: 2021-9-3 18:36 发布者: 大米
在支持页面 可见性API的浏览器中,当用户看不到网页时(如浏览器选项卡处于非活动状态、浏览器窗口最小化等),轮播图将避免滑动。
请注意,不支持嵌套轮播图,轮播图通常不符合可访问性标准。
需要将.active
类添加到其中一张幻灯片中,否则轮播将不可见。另外,请确保在 .carousel
上为可选控件设置一个唯一的id,尤其是在一个页面上使用多个carousel
时。控件和指示符元素必须具有与 .carousel
元素的id匹配的 data-bs-target
属性(或链接的 href
)。
<div id="carouselExampleSlidesOnly" class="carousel slide" data-bs-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
</div>
</div>
</div>
<div id="carouselExampleControls" class="carousel slide" data-bs-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleControls" role="button" data-bs-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="visually-hidden">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleControls" role="button" data-bs-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="visually-hidden">Next</span>
</a>
</div>
<div id="carouselExampleIndicators" class="carousel slide" data-bs-ride="carousel">
<ol class="carousel-indicators">
<li data-bs-target="#carouselExampleIndicators" data-bs-slide-to="0" class="active"></li>
<li data-bs-target="#carouselExampleIndicators" data-bs-slide-to="1"></li>
<li data-bs-target="#carouselExampleIndicators" data-bs-slide-to="2"></li>
</ol>
<div class="carousel-inner">
<div class="carousel-item active">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleIndicators" role="button" data-bs-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="visually-hidden">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleIndicators" role="button" data-bs-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="visually-hidden">Next</span>
</a>
</div>
<div id="carouselExampleCaptions" class="carousel slide" data-bs-ride="carousel">
<ol class="carousel-indicators">
<li data-bs-target="#carouselExampleCaptions" data-bs-slide-to="0" class="active"></li>
<li data-bs-target="#carouselExampleCaptions" data-bs-slide-to="1"></li>
<li data-bs-target="#carouselExampleCaptions" data-bs-slide-to="2"></li>
</ol>
<div class="carousel-inner">
<div class="carousel-item active">
<img src="..." class="d-block w-100" alt="...">
<div class="carousel-caption d-none d-md-block">
<h5>First slide label</h5>
<p>Nulla vitae elit libero, a pharetra augue mollis interdum.</p>
</div>
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
<div class="carousel-caption d-none d-md-block">
<h5>Second slide label</h5>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</p>
</div>
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
<div class="carousel-caption d-none d-md-block">
<h5>Third slide label</h5>
<p>Praesent commodo cursus magna, vel scelerisque nisl consectetur.</p>
</div>
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleCaptions" role="button" data-bs-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="visually-hidden">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleCaptions" role="button" data-bs-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="visually-hidden">Next</span>
</a>
</div>
<div id="carouselExampleFade" class="carousel slide carousel-fade" data-bs-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleFade" role="button" data-bs-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="visually-hidden">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleFade" role="button" data-bs-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="visually-hidden">Next</span>
</a>
</div>
<div id="carouselExampleInterval" class="carousel slide" data-bs-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active" data-bs-interval="10000">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item" data-bs-interval="2000">
<img src="..." class="d-block w-100" alt="...">
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleInterval" role="button" data-bs-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="visually-hidden">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleInterval" role="button" data-bs-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="visually-hidden">Next</span>
</a>
</div>
<div id="carouselExampleDark" class="carousel carousel-dark slide" data-bs-ride="carousel">
<ol class="carousel-indicators">
<li data-bs-target="#carouselExampleDark" data-bs-slide-to="0" class="active"></li>
<li data-bs-target="#carouselExampleDark" data-bs-slide-to="1"></li>
<li data-bs-target="#carouselExampleDark" data-bs-slide-to="2"></li>
</ol>
<div class="carousel-inner">
<div class="carousel-item active" data-bs-interval="10000">
<img src="..." class="d-block w-100" alt="...">
<div class="carousel-caption d-none d-md-block">
<h5>First slide label</h5>
<p>Nulla vitae elit libero, a pharetra augue mollis interdum.</p>
</div>
</div>
<div class="carousel-item" data-bs-interval="2000">
<img src="..." class="d-block w-100" alt="...">
<div class="carousel-caption d-none d-md-block">
<h5>Second slide label</h5>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</p>
</div>
</div>
<div class="carousel-item">
<img src="..." class="d-block w-100" alt="...">
<div class="carousel-caption d-none d-md-block">
<h5>Third slide label</h5>
<p>Praesent commodo cursus magna, vel scelerisque nisl consectetur.</p>
</div>
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleDark" role="button" data-bs-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="visually-hidden">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleDark" role="button" data-bs-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="visually-hidden">Next</span>
</a>
</div>
通过数据属性
data-bs-slide
接受关键字 prev
或 next
,这会改变相对于当前位置的幻灯片位置。或者,使用 data-bs-slide-to
将原始幻灯片索引传递给轮播图 data-bs-slide-to="2"
,这会将幻灯片位置移到以0开头的特定索引。
data-bs-ride="carousel"
属性用于在页面加载时将轮播图标记为动画。如果不使用 data-bs-ride="carousel"
来初始化carousel
,则必须自己初始化它。它不能与同一个carousel
的显式JavaScript初始化(冗余和不必要的)结合使用。
通过 JavaScript
手动调整:
var myCarousel = document.querySelector('#myCarousel')
var carousel = new bootstrap.Carousel(myCarousel)
选项
选项可以通过数据属性或JavaScript传递。对于数据属性,将选项名称追加到 data-bs-
,如 data-bs-interval=""
。
名称 | 类型 | 默认 | 描述 |
---|---|---|---|
interval |
number | 5000 |
在延迟时间过后自动循环轮播图片。如果为 false, 则轮播不会自动循环。 |
keyboard |
boolean | true |
轮播是否应该对键盘事件做出反应。 |
pause |
string | boolean | "hover" |
如果设置为
在支持触摸的设备上,当设置为 |
slide |
string | boolean | false |
用户手动循环第一项后,自动播放轮播。 如果为“轮播”,则在加载时自动播放轮播图。 |
wrap |
boolean | true |
轮播是否应该连续循环或强行停止。 |
touch |
boolean | true |
轮播是否应支持触摸屏设备上的向左/向右滑动交互。 |
方法
您可以使用carousel构造函数创建一个轮播图实例,例如,使用其他选项初始化并开始在项之间循环:
var myCarousel = document.querySelector('#myCarousel')
var carousel = new bootstrap.Carousel(myCarousel, {
interval: 2000,
wrap: false
})
方法 | 描述 |
---|---|
cycle |
从左到右循环播放轮播项目。 |
pause |
阻止轮播在各个项目之间循环。 |
prev |
循环到上一个项目。 在显示上一个项目之前 (例如,在 slid.bs.carousel 事件发生 之前)返回到调用方。
|
next |
循环到下一个项目。 在显示下一项之前(例如,在 slid.bs.carousel 事件发生之前)返回到调用方。
|
nextWhenVisible |
当页面不可见或轮播或其父项不可见时,请勿将轮播循环到下一个。 在显示目标项目之前返回调用者 |
to |
将轮播循环到特定帧(从0开始,类似于数组)。 在显示目标项目之前(例如,在 slid.bs.carousel 事件发生之前)返回到调用方。
|
dispose |
销毁元素的轮播。 (删除DOM元素上存储的数据) |
getInstance |
允许您获取与DOM元素关联的轮播实例的静态方法。 |
事件
direction
: 轮播图滑动的方向 ("left"
或者"right"
).relatedTarget
: 作为活动项滑动到适当位置的DOM元素。from
: 当前项的索引to
: 下一项的索引
所有滑动事件都会在轮播图本身触发 (即在 <div class="carousel">
处)
事件类型 | 描述 |
---|---|
slide.bs.carousel |
调用 slide 实例方法时立即触发。 |
slid.bs.carousel |
轮播完成幻灯片切换后触发。 |
var myCarousel = document.getElementById('myCarousel')
myCarousel.addEventListener('slide.bs.carousel', function () {
// do something...
})