zoukankan      html  css  js  c++  java
  • 2019.08.29定时器以及轮播图

    js 定时器有以下两个方法:

    setInterval() :按照指定的周期(以毫秒计)来调用函数或计算表达式。方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。循环

    setTimeout() :在指定的毫秒数后调用函数或计算表达式。单次

    用法:

    var time = setInterval(function(){

    需要循环的内容

    },1000)每循环一次的毫秒数

    因此,使用定时器可以完成轮播图

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>setTnterval</title>
    <style>
    h1{
    300px;
    margin: auto;
    }
    div{
    1000px;
    height: 600px;
    margin: 50px auto;
    }
    p{
    display: inline-block;
    30px;
    height: 30px;
    background-color: #fff;
    border-radius: 30px;
    position: relative;
    top: -95px;
    left: 40%;
    margin-left: 10px;
    }
    </style>
    </head>
    <body>
    <h1>轮播图</h1>
    <div></div>
    <p id="p0"></p>
    <p id="p1"></p>
    <p id="p2"></p>
    <p id="p3"></p>
    <p id="p4"></p>

    <script>

    var a = document.getElementsByTagName("p")
    function fun(){//每次运行前导航块块颜色为白
    for(var j = 0;j<a.length;j++){
    a[j].style.backgroundColor = '#fff'
    }
    }
    function funny(p){//点击导航块块切换
    for(var i = 0;i<a.length;i++){
    (function (i){
    a[i].onclick = function(){
    clearInterval(p);
    fun();
    a[i].style.backgroundColor = '#00f';
    div.innerHTML = "<img src='timg"+i+".jpg' width = '1000px' height = '600px'>";
    timer(i);
    }
    })(i)
    }
    }
    var div = document.getElementsByTagName('div')[0];
    var i = 0;
    function timer(i){//定时器
    var photo = setInterval(function(){
    fun();
    i<5?div.innerHTML = "<img src='timg"+i+".jpg' width = '1000px' height = '600px'>":i=0;
    div.innerHTML = "<img src='timg"+i+".jpg' width = '1000px' height = '600px'>";
    a[i].style.backgroundColor = '#00f'
    i = ++i;
    },1000);
    div.onmouseover = function(){//鼠标进入事件
    clearInterval(photo);
    };
    div.onmouseout = function(){//鼠标移开事件
    timer(i);
    };
    funny(photo);
    }
    timer();
    </script>

    上述代码为直接进行切换,即无左右滑动效果的轮播图

    今后我会将切换式的轮播图也发出来

  • 相关阅读:
    Unity中 mesh生成斜坡
    设计模式
    Go语言高级编程
    Go语言高级编程
    agentzh 的 Nginx 教程(版本 2020.03.19)
    ubuntu18安装mysql5.7并配置远程连接
    创建图库
    交点修改
    显示中文
    浅谈前端水印
  • 原文地址:https://www.cnblogs.com/awei313558147/p/11537182.html
Copyright © 2011-2022 走看看