JS特效一:图片轮播图(JS必须掌握的特效)

发布时间:2020-12-04 20:51:30 作者:赚钱养个快乐小智障 来源:CSDN 浏览量(104) 点赞(24)
摘要:今天来讲一个很常用的js特效,这个不用说了,是个网页应该都可以看到,虽然不难,但是对很多人来说,也是需要一定的基础来掌握(html和css不难,js需要认真看,细细品)。话不多说,上图片(默认为第一张图片)而且是响应式的(随着屏幕大小的变化而变化!):需要注意的点都给大家圈起来了!需要注意的就是还有一些css样式

20201201214926949.jpg

今天来讲一个很常用的js特效,这个不用说了,是个网页应该都可以看到,虽然不难,但是对很多人来说,也是需要一定的基础来掌握(html和css不难,js需要认真看,细细品)。话不多说,上图片(默认为第一张图片)而且是响应式的(随着屏幕大小的变化而变化!):

20201201215452645.jpg20201201215454933 (1).jpg

20201201215456574.jpg

需要注意的点都给大家圈起来了!

需要注意的就是还有一些css样式

主要用到就是点击的时候css属性的转移,重点都在代码中标注出来了,希望大家认真琢磨

最后附上源码!

html代码:

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0,,shrink-to-fit=no">
    <title>响应式轮播图</title>
    <link rel="stylesheet" href="1.css"></head><body>
    <!-- 设置图片组(三张图片) -->
    <div class="slideshow-container">
        <div class="mySlides fade">
            <div class="numbertext">1 / 3</div>
            <img src="img/1.jpg" style="width:100%">
            <div class="text">美丽的山川</div>
        </div>
        <div class="mySlides fade">
            <div class="numbertext">2 / 3</div>
            <img src="img/2.jpg" style="width:100%">
            <div class="text">绚丽的云彩</div>
        </div>

        <div class="mySlides fade">
            <div class="numbertext">3 / 3</div>
            <img src="img/3.jpg" style="width:100%">
            <div class="text">呆萌的兔子</div>
        </div>

        <!-- 设置按钮,并添加一个js事件 -->
        <a class="prev" onclick="plusSlides(-1)">❮</a>
        <a class="next" onclick="plusSlides(1)">❯</a>
    </div>
    <br>

    <!-- 设置底部原点,并添加一个js事件 -->
    <div style="text-align:center">
        <span class="dot" onclick="currentSlide(1)"></span>
        <span class="dot" onclick="currentSlide(2)"></span>
        <span class="dot" onclick="currentSlide(3)"></span>
    </div>

    <script src="1.js"></script>
        </body>
        </html>

CSS代码:

* {
    /* 不清除盒子的margin,默认还有8px */
    box-sizing: border-box}body {
    font-family: Verdana, sans-serif;}.mySlides {
    /* 先让他们都隐藏起来 */
    display: none}/* 幻灯片容器 */.slideshow-container {
    max-width: 1000px;
    position: relative;
    margin: auto;}/* 下一张 & 上一张 按钮 */.prev,
.next {
    cursor: pointer;
    position: absolute;
    top: 50%;
    width: auto;
    /* 为了使按钮居中 */
    margin-top: -22px;
    padding: 16px;
    color: white;
    font-weight: bold;
    font-size: 18px;
    transition: 0.6s ease;
    border-radius: 0 3px 3px 0;}/* 定位 "下一张" 按钮靠右 */.next {
    right: 0;
    border-radius: 3px 0 0 3px;}.prev:hover,
.next:hover {
    background-color: rgba(0, 0, 0, 0.8);}/* 标题设置属性 */.text {
    color: #f2f2f2;
    font-size: 15px;
    padding: 8px 12px;
    position: absolute;
    bottom: 8px;
    width: 100%;
    text-align: center;}/* 数字 (1/3 等) */.numbertext {
    color: #f2f2f2;
    font-size: 12px;
    padding: 8px 12px;
    position: absolute;
    top: 0;}/* 底部小原点 */.dot {
    cursor: pointer;
    height: 13px;
    width: 13px;
    margin: 0 2px;
    background-color: #bbb;
    border-radius: 50%;
    display: inline-block;
    transition: background-color 0.6s ease;}.active,
.dot:hover {
    background-color: #717171;}/* 淡出动画 */.fade {
    -webkit-animation-name: fade;
    -webkit-animation-duration: 1s;
    animation-name: fade;
    animation-duration: 1s;}@-webkit-keyframes fade {
    from {
        opacity: .6    }
    to {
        opacity: 1    }}@keyframes fade {
    from {
        opacity: .6    }
    to {
        opacity: 1    }}

JS代码:

// 设置一个参数记录当前是第几张图片var slideIndex = 1;showSlides(slideIndex);// 设置按钮的点击事件function plusSlides(n) {
    showSlides(slideIndex += n);}// 设置最下边小原点的点击事件function currentSlide(n) {
    showSlides(slideIndex = n);}// 设置当前在第几张的计算方式function showSlides(n) {
    var i;
    var slides = document.getElementsByClassName("mySlides");
    var dots = document.getElementsByClassName("dot");
    if (n > slides.length) { slideIndex = 1 }
    if (n < 1) { slideIndex = slides.length }
    for (i = 0; i < slides.length; i++) {
        slides[i].style.display = "none";
    }
    for (i = 0; i < dots.length; i++) {
        dots[i].className = dots[i].className.replace(" active", "");
    }
    // 一旦设置这个属性,所在的图片就会显示
    slides[slideIndex - 1].style.display = "block";
    // 一旦设置这个属性,所在的小圆点就会变化
    dots[slideIndex - 1].className += " active";}

彩蛋来了!将以上的js文件换成下面的会实现自动定时轮播
还等什么,赶紧去试试吧!喜欢的记得留下三连哦!手动比心

var slideIndex = 0;showSlides();
 function showSlides() {
    var i;
    var slides = document.getElementsByClassName("mySlides");
    var dots = document.getElementsByClassName("dot");
    for (i = 0; i < slides.length; i++) {
       slides[i].style.display = "none";  
    }
    slideIndex++;
    if (slideIndex > slides.length) {slideIndex = 1}    
    for (i = 0; i < dots.length; i++) {
        dots[i].className = dots[i].className.replace(" active", "");
    }
    slides[slideIndex-1].style.display = "block";  
    dots[slideIndex-1].className += " active";
    setTimeout(showSlides, 2000); // 切换时间为 2 秒


二维码

扫一扫,关注我们

声明:本文由【达扬网络】编辑上传发布,转载此文章须经作者同意,并请附上出处【达扬网络】及本页链接。如内容、图片有任何版权问题,请联系我们进行处理。

现在,非常期待与您的一次邂逅

青海达扬网络传媒有限责任公司努力让每一次邂逅总能超越期待!

您身边的【互联网信息化建设专家】

搜索千万次不如咨询1次

主营项目:网站建设,手机网站,软件开发,政府网站建设,信息系统开发,网络安全维护,app开发等

立即咨询 0971-6275815
在线客服
嘿,我来帮您!