原生js实现旋转木马效果

 更新时间:2022年02月23日 14:57:15   作者:hind sight  
这篇文章主要为大家详细介绍了原生js实现旋转木马效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了js实现旋转木马效果的具体代码,供大家参考,具体内容如下

html部分

<div class="wrap" id="wrap">
    <div class="slide" id="slide">
        <ul>
            <li><a href=""><img src="images/slidepic1.jpg" alt=""></a></li>
            <li><a href=""><img src="images/slidepic2.jpg" alt=""></a></li>
            <li><a href=""><img src="images/slidepic3.jpg" alt=""></a></li>
            <li><a href=""><img src="images/slidepic4.jpg" alt=""></a></li>
            <li><a href=""><img src="images/slidepic5.jpg" alt=""></a></li>
        </ul>
        <div class="arrow" id="arrow">
            <a href="javascript:" id="next"></a>
            <a href="javascript:" id="prev"></a>
        </div>
    </div>
</div>

css部分

@charset "UTF-8";
/*初始化  reset*/
blockquote,body,button,dd,dl,dt,fieldset,form,h1,h2,h3,h4,h5,h6,hr,input,legend,li,ol,p,pre,td,textarea,th,ul{margin:0;padding:0}
body,button,input,select,textarea{font:12px/1.5 "Microsoft YaHei", "微软雅黑", SimSun, "宋体", sans-serif;color: #666;}
ol,ul{list-style:none}
a{text-decoration:none}
fieldset,img{border:0;vertical-align:top;}
a,input,button,select,textarea{outline:none;}
a,button{cursor:pointer;}
 
.wrap {
    margin: 100px auto;
    width: 1200px;
}
.slide {
    height: 500px;
    position: relative;
}
 
.slide li {
    position: absolute;
    left: 200px;
    top: 0;
}
.slide li img {
    width: 100%;
}
.arrow {
    opacity: 0;
}
#next,#prev {
    width: 76px;
    height: 112px;
    position: absolute;
    top: 50%;
    margin-top: -56px;
    background: url("../images/prev.png") no-repeat;
    z-index: 99;
}
#next {
    background-image: url("../images/next.png");
    right: 0;
}

js部分

<script src="common.js"></script>
    <script>
        var config = [
            {
                width: 400,
                opacity: 0.2,
                height: 250,
                left: 50,
                top: 20,
                zIndex: 2
            },//0
            {
                width: 600,
                opacity: 0.7,
                height: 350,
                left: 0,
                top: 70,
                zIndex: 3
            },//1
            {
                width: 800,
                opacity: 1,
                height: 500,
                left: 200,
                top: 100,
                zIndex: 4
            },//2
            {
                width: 600,
                opacity: 0.7,
                height: 350,
                left: 600,
                top: 70,
                zIndex: 3
            },//3
            {
                width: 400,
                opacity: 0.2,
                height: 250,
                left: 750,
                top: 20,
                zIndex: 2
            }//4
        ];
        //页面加载事件
        window.onload = function () {
            var flag=true;//默认所有的动画都结束了
            //获取li标签
            var list = my$("slide").getElementsByTagName("li");
            //散开图片
            function assign() {
                for (var i = 0; i < list.length; i++) {
                    animate(list[i], config[i],function () {
                        flag=true;//回调函数,当动画加载完后,flag变为true
                    });
                }
            }
            assign();
            //点击右边焦点
            my$("next").onclick = function () {
                if (flag){
                    flag=false;
                    config.push(config.shift());//把数组中的第一个元素作为返回值并追加加到这个数组的最后面
                    assign();
                }
            };
            //点击左边焦点
            my$("prev").onclick = function () {
                if (flag){
                    flag=false;
                    config.unshift(config.pop());//把数组的最后一个元素作为返回值并追加到这个数组的最前面
                    assign();
                }
 
            };
            //鼠标进入逐渐的显示左右焦点
            my$("slide").onmouseover=function () {
               animate(my$("arrow"),{"opacity":1});
            };
            //鼠标离开隐藏
            my$("slide").onmouseout = function () {
                animate(my$("arrow"),{"opacity":0});
            };
        };
</script>

common.js部分

//根据id获取元素对象
function my$(id) {
    return document.getElementById(id);
}
/*
* element---任意的元素
* attr---属性
* */
function getAttrValue(element,attr) {
    return element.currentStyle?element.currentStyle[attr] : window.getComputedStyle(element,null)[attr]||0;
}
//动画函数
function animate(element,json,fn) {
    clearInterval(element.timeId);
    element.timeId=setInterval(function () {
        var flag=true;//假设都达到了目标
        for(var attr in json){
            if(attr=="opacity"){//判断属性是不是opacity
                var current= getAttrValue(element,attr)*100;
                //每次移动多少步
                var target=json[attr]*100;//直接赋值给一个变量,后面的代码都不用改
                var step=(target-current)/10;//(目标-当前)/10
                step=step>0?Math.ceil(step):Math.floor(step);
                current=current+step;
                element.style[attr]=current/100;
            }else if(attr=="zIndex"){//判断属性是不是zIndex
                element.style[attr]=json[attr];
            }else{//普通的属性
 
                //获取当前的位置----getAttrValue(element,attr)获取的是字符串类型
                var current= parseInt(getAttrValue(element,attr))||0;
                //每次移动多少步
                var target=json[attr];//直接赋值给一个变量,后面的代码都不用改
                var step=(target-current)/10;//(目标-当前)/10
                step=step>0?Math.ceil(step):Math.floor(step);
                current=current+step;
                element.style[attr]=current+"px";
            }
            if(current!=target){
                flag=false;//如果没到目标结果就为false
            }
        }
        if(flag){//结果为true
            clearInterval(element.timeId);
            if(fn){//如果用户传入了回调的函数
                fn(); //就直接的调用,
            }
        }
        console.log("target:"+target+"current:"+current+"step:"+step);
    },10);
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 微信小程序实现日期范围选择

    微信小程序实现日期范围选择

    这篇文章主要为大家详细介绍了微信小程序实现日期范围选择,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • JS实现的input选择图片本地预览功能示例

    JS实现的input选择图片本地预览功能示例

    这篇文章主要介绍了JS实现的input选择图片本地预览功能,涉及javascript针对页面元素属性动态操作相关实现技巧,需要的朋友可以参考下
    2018-08-08
  • webgl实现物体描边效果的方法介绍

    webgl实现物体描边效果的方法介绍

    这篇文章主要给大家介绍了关于webgl实现物体描边效果的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用webgl具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-11-11
  • JavaScript中数组slice和splice的对比小结

    JavaScript中数组slice和splice的对比小结

    相信对很多学习JavaScript语言的人来说,都会经常搞不清slice和splice这两个方法。它们虽然名称相似,但是功能却完全不同。所以这篇文章就给大家详细整理了关于JavaScript中数组slice和splice的对比,有需要的可以参考学习。
    2016-09-09
  • 简单实现js鼠标跟随效果

    简单实现js鼠标跟随效果

    这篇文章主要教大家如何简单实现js鼠标跟随效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • 基于JS实现页面视频video标签禁止下载(下载按钮+右击菜单)

    基于JS实现页面视频video标签禁止下载(下载按钮+右击菜单)

    最近做项目遇到这样的需求,禁止用户浏览页面的时候下载页面的视频,网上看到下载视频的方法有两种,本文对每种方法做详细分析,对js禁止下载视频相关知识感兴趣的朋友一起看看吧
    2024-02-02
  • js展开闭合效果演示代码

    js展开闭合效果演示代码

    本文为大家介绍下js如何实现展开闭合效果,具体代码如下,感兴趣的朋友可以参考下哈,希望对大家有所帮助
    2013-07-07
  • JS+CSS实现可拖动的弹出提示框

    JS+CSS实现可拖动的弹出提示框

    这篇文章主要介绍了JS+CSS实现可拖动的弹出提示框,涉及针对鼠标事件及html元素的操作技巧,非常具有实用价值,需要的朋友可以参考下
    2015-02-02
  • 浅谈javascript中的instanceof和typeof

    浅谈javascript中的instanceof和typeof

    这篇文章主要简单介绍了javascript中的instanceof和typeof的相关资料,需要的朋友可以参考下
    2015-02-02
  • JS判断移动端访问设备并加载对应CSS样式

    JS判断移动端访问设备并加载对应CSS样式

    JS判断不同web访问环境,主要针对移动设备,提供相对应的解析方案,本例是加载不同的css样式
    2014-06-06

最新评论