原生JS实现风箱式demo,并封装了一个运动框架(实例代码)
来源: 阅读:891 次 日期:2016-07-29 15:52:02
温馨提示: 小编为您整理了“原生JS实现风箱式demo,并封装了一个运动框架(实例代码)”,方便广大网友查阅!

下面小编就为大家带来一篇原生JS实现风箱式demo,并封装了一个运动框架(实例代码)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。

首先,在前端的学习过程中,轮播图是我们一定要学习的,所以为了更加高效的实现各种轮播图,封装了一个运动的框架。

function getStyle(obj,attr) {

  if(obj.currentStyle){

    return obj.currentStyle[attr];//为了获取IE下的属性值

  }else{

    return window.getComputedStyle(obj,null)[attr];//为了获取W3C浏览器下的属性值

  }

}

function animate(obj,json){

  clearInterval(obj.timer);

  obj.timer = setInterval(function () {

    var flag = true;

    var current = 0;

    for(var attr in json){

      if(attr == 'opacity'){

        current = parseInt(getStyle(obj,attr)*100);

      }else{

        current = parseInt(getStyle(obj,attr));

      };

      var step = (json[attr] - current) / 10;

      step = step > 0 ? Math.ceil(step) : Math.floor(step);

      //先判断属性是否为透明度

      if(attr == 'opacity'){

        //首先判断浏览器是否支持opacity

        if('opacity' in obj.style){

          obj.style.opacity = (current + step) / 100;

        }else{

          obj.style.filter = 'alpha(opacity = ' + (current + step) + ')';

        }

      //再判断属性是否为z-index

      }else if(attr == 'zIndex'){

        obj.style.zIndex = json[attr];

      //最后再判断

      }else{

        obj.style[attr] = current + step + 'px';

      }

      if(current != json[attr]){

        flag = false;

      }

    }

    if(flag){

      clearInterval(obj.timer);

    }

  },5);

}

在该框架中兼容了不同的浏览器,并且允许传入opacity和z-index这样的属性,当然,像width,height,left,right这样常见的属性是必不可少的。利用该框架,可以实现非常棒的效果。所以现在开始正式做该DEMO。

首先是index.html的制作。

<div id="box">

  <ul>

    <li></li>

    <li></li>

    <li></li>

    <li></li>

    <li></li>

  </ul>

</div>

index.html的制作非常的简单,我们会将图片作为li的背景图片在javascript中进行插入。之后,我们进行CSS样式的调节。

*{

    margin:0px;

    padding:0px;

  }

  #box{

    width:1300px;

    height:400px;

    margin:100px auto;

    overflow: hidden;

  }

  #box ul{

    height:400px;

    width:1300px;

  }

  #box ul li{

    width:240px;

    height:400px;

    float:left;

    overflow: hidden;

  }

javascript的代码如下:

window.onload = function () {

    var box = document.getElementById('box');

    var aLi = box.children[0].children;

    for(var i=0;i<aLi.length;i++){

      aLi[i].style.backgroundImage = 'url(' + 'images/' + (i + 1) + '.jpg';

      aLi[i].onmouseover = function(){

        for(var i=0;i<aLi.length;i++){

          animate(aLi[i],{width:100});

        }

        animate(this,{width:800});

      };

      aLi[i].onmouseout = function(){

        for(var i=0;i<aLi.length;i++){

          animate(aLi[i],{width:240});

        }

      }

    }

  }

这样使用原生JS实现的风箱效果demo就实现了,当然,还可以利用封装好的animate框架实现类似网易的轮播图效果。

以上这篇原生JS实现风箱式demo,并封装了一个运动框架(实例代码)就是小编分享给大家的全部内容了,希望能给大家一个参考

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map