IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 【前端实现页面总结二】--JS轮播图(原生+jQuery+vue)实现【均可运行】 -> 正文阅读

[JavaScript知识库]【前端实现页面总结二】--JS轮播图(原生+jQuery+vue)实现【均可运行】

写在前面 :

  • 原生JS实现自动播放+手动播放
  • 展示图片的div块无需粘来粘去,通过拼接字符串 将 数组 中的元素上传到页面

每种方式实现的具体效果都不同哦!都可运行!!!

一、原生JS实现

效果展示

请添加图片描述

代码展示

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>javascript幻灯片代码</title>
    <style>
        * {
            box-sizing: border-box;
        }
        
        body {
            font-family: Verdana, sans-serif;
        }
        
        .mySlides {
            display: none;
        }
        /* 幻灯片容器 */
        
        .slidedshow-container {
            max-width: 1000px;
            position: relative;
            margin: auto;
        }
        
        .prev,
        .next {
            cursor: pointer;
            position: absolute;
            top: 50%;
            width: auto;
            margin-top: -22px;
            padding: 16px;
            color: red;
            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, .8);
        }
        /* 标题文本 */
        
        .text {
            color: #f2f2f2;
            font-size: 15px;
            padding: 8px 12px;
            position: absolute;
            bottom: 8px;
            width: 100%;
            text-align: center;
        }
        
        .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: 1.5s;
            animation-name: fade;
            animation-duration: 1.5s;
        }
        
        @-webkit-keyframes fade {
            from {
                opacity: .4
            }
            to {
                opacity: 1
            }
        }
        
        @keyframes fade {
            from {
                opacity: .4
            }
            to {
                opacity: 1
            }
        }
    </style>
</head>

<body>
    <!-- 放置图片的盒子 -->
    <div class="slideshow-container">
        <!-- 左右按钮切换图片 -->
        <div id="slideshow-container"></div>
        <a href="javascript:;" class="prev" onclick="plusSlides(-1)">??</a>
        <a href="javascript:;" class="next" onclick="plusSlides(1)">??</a>
    </div>
    <br>
    <!-- 下方小li跟随图片滚动 -->
    <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>
        // 下面这段拼接字符串代码上传到div盒子里面
        var mynumbertext = new Array("1 / 3", "2 / 3", "3 / 3");
        var imgsrc = new Array("https://c.runoob.com/wp-content/uploads/2017/01/img_nature_wide.jpg", "https://c.runoob.com/wp-content/uploads/2017/01/img_fjords_wide.jpg", "https://c.runoob.com/wp-content/uploads/2017/01/img_mountains_wide.jpg");
        var html = '';
        for (var i = 0; i < mynumbertext.length; i++) {
            html += "<div class=\"mySlides fade\">";
            html += "<div class=\"numbertext\">";
            html += mynumbertext[i];
            html += "</div><img src=\"";
            html += imgsrc[i];
            html += "\" style=\"width:100%\"><div class=\"text\">文本";
            html += i + 1;
            html += "</div></div>";
        }
        // console.log(html);
        document.getElementById("slideshow-container").innerHTML = html;
    </script>

    <!-- 下面是手动播放代码 -->
    <!-- <script>
        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";
        }
    </script> -->

    <!-- !!!!自动播放!!!! -->
    <script>
        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); //切换时间为2s
        }
    </script>
</body>



</html>

二、jQuery实现轮播图

上代码:

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8" name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">
    <title>JQuery轮播图</title>
    <script src="https://cdn.bootcss.com/jquery/2.0.2/jquery.min.js" type="text/javascript"></script>
    <style>
        * {
            padding: 0;
            margin: 0;
        }
        
        .container {
            width: 600px;
            height: 400px;
            overflow: hidden;
            position: relative;
            margin: 0 auto;
        }
        
        .list {
            width: 3000px;
            height: 400px;
            position: absolute;
        }
        
        .list>img {
            float: left;
            width: 600px;
            height: 400px;
        }
        
        .pointer {
            position: absolute;
            width: 100px;
            bottom: 20px;
            left: 250px;
        }
        
        .pointer>span {
            cursor: pointer;
            display: inline-block;
            width: 10px;
            height: 10px;
            background: #7b7d80;
            border-radius: 50%;
            border: 1px solid #fff;
        }
        
        .pointer .on {
            background: #28a4c9;
        }
        
        .arrow {
            position: absolute;
            text-decoration: none;
            width: 40px;
            height: 40px;
            background: #727d8f;
            color: #fff;
            font-weight: bold;
            line-height: 40px;
            text-align: center;
            top: 180px;
            display: none;
        }
        
        .arrow:hover {
            background: #0f0f0f;
        }
        
        .left {
            left: 0;
        }
        
        .right {
            right: 0;
        }
        
        .container:hover .arrow {
            display: block;
        }
    </style>
</head>

<body>
    <div class="container">
        <div class="list" style="left:0px;">
            <!--<img src="../static/image/photo1.jpg" alt="5"/>-->
            <img src="https://c.runoob.com/wp-content/uploads/2017/01/img_nature_wide.jpg" alt="1" />
            <img src="https://c.runoob.com/wp-content/uploads/2017/01/img_fjords_wide.jpg" alt="2" />
            <img src="https://c.runoob.com/wp-content/uploads/2017/01/img_mountains_wide.jpg" alt="3" />
        </div>
        <div class="pointer">
            <span index="1" class="on"></span>
            <span index="2"></span>
            <span index="3"></span>

        </div>
        <a href="#" rel="external nofollow" rel="external nofollow" class="arrow left">&lt;</a>
        <a href="#" rel="external nofollow" rel="external nofollow" class="arrow right">&gt;</a>
    </div>
    <script>
        var imgCount = $("img").length;
        var index = 1;
        var intervalId;
        var buttonSpan = $('.pointer')[0].children; //htmlCollection 集合
        //自动轮播功能 使用定时器
        autoNextPage();

        function autoNextPage() {
            intervalId = setInterval(function() {
                nextPage(true);
            }, 3000);
        }
        //当鼠标移入 停止轮播
        $('.container').mouseover(function() {
            console.log('hah');
            clearInterval(intervalId);
        });
        // 当鼠标移出,开始轮播
        $('.container').mouseout(function() {
            autoNextPage();
        });
        //点击下一页 上一页的功能
        $('.left').click(function() {
            nextPage(false);
        });
        $('.right').click(function() {
            nextPage(true);
        });
        //小圆点的相应功能 事件委托
        clickButtons();

        function clickButtons() {
            var length = buttonSpan.length;
            for (var i = 0; i < length; i++) {
                buttonSpan[i].onclick = function() {
                    $(buttonSpan[index - 1]).removeClass('on');
                    if ($(this).attr('index') == 1) {
                        index = imgCount;
                    } else {
                        index = $(this).attr('index') - 1;
                    }
                    nextPage(true);

                };
            }
        }

        function nextPage(next) {
            var targetLeft = 0;
            //当前的圆点去掉on样式
            $(buttonSpan[index - 1]).removeClass('on');
            if (next) { //往后走
                if (index == imgCount) { //到最后一张,直接跳到第一张
                    targetLeft = 0;
                    index = 1;
                } else {
                    index++;
                    targetLeft = -600 * (index - 1);
                }

            } else { //往前走
                if (index == 1) { //在第一张,直接跳到第五张
                    index = 5;
                    targetLeft = -600 * (imgCount - 1);
                } else {
                    index--;
                    targetLeft = -600 * (index - 1);
                }

            }
            $('.list').animate({
                left: targetLeft + 'px'
            });
            //更新后的圆点加上样式
            $(buttonSpan[index - 1]).addClass('on');


        }
    </script>
</body>

</html>

三、 VUE实现轮播图

上代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <!-- banner轮播图片 -->
    <div class="center">
        <div class="banner">
            <a href=""><img v-for="(item,index) in dataList" :key="index" :src="item" v-show="n === index" alt="" @mouseenter="clearGo" @mouseleave="go"></a>
        </div>
    </div>
    <!-- 引入vue的开发环境完成轮播图的制作 -->
    <!-- 开发环境版本,包含了有帮助的命令行警告 -->
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script>
        var figure = new Vue({
            el: '.banner ',
            data: {
                dataList: [
                    "https://c.runoob.com/wp-content/uploads/2017/01/img_mountains_wide.jpg",
                    "https://c.runoob.com/wp-content/uploads/2017/01/img_fjords_wide.jpg",
                    "https://c.runoob.com/wp-content/uploads/2017/01/img_nature_wide.jpg",
                    "https://c.runoob.com/wp-content/uploads/2017/01/img_mountains_wide.jpg"

                ],
                n: 0, //默认显示图片
                interId: null //定时器
            },
            methods: {
                go() { //改变变量n
                    this.interId = setInterval(() => {
                        this.n++;
                        if (this.n == this.dataList.length) {
                            this.n = 0;
                        }
                    }, 2000)
                },
                clearGo() {
                    clearInterval(this.interId)
                },
                clickPage(str) {
                    if (str === 'up ') {
                        //如果是上一页,先判断是不是等于0,如果等于0,就让它从最大的照片的下标开始
                        if (this.n == 0) {
                            this.n = this.dataList.length;
                        }
                        this.n--;
                    } else {
                        this.n++;
                        if (this.n == this.dataList.length) {
                            this.n = 0;
                        }
                    }
                }
            },
            mounted() {
                this.go()
            }

        })
    </script>

</body>

</html>
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-18 11:06:33  更:2021-11-18 11:07:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 10:23:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码