原生JS实现风箱式demo,并封装了一个运动框架(实例代码)


Posted in Javascript onJuly 22, 2016

声明,该DEMO依托于某个培训机构中,非常感谢这个培训结构。话不多说,现在开始改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,并封装了一个运动框架(实例代码)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript-Mozilla和IE中的一个函数直接量的问题分析
Aug 12 Javascript
XmlUtils JS操作XML工具类
Oct 01 Javascript
javascript动画浅析
Aug 30 Javascript
JS判断当前日期是否大于某个日期的实现代码
Sep 02 Javascript
window.open的页面如何刷新(父页面)上层页面
Dec 28 Javascript
使用PHP+JQuery+Ajax分页的实现
Apr 23 Javascript
javascript获取当前的时间戳的方法汇总
Jul 26 Javascript
JavaScript无阻塞加载和defer、async详解
Feb 26 Javascript
AngularJS实现的获取焦点及失去焦点时的表单验证功能示例
Oct 25 Javascript
angular实现页面打印局部功能的思考与方法
Apr 13 Javascript
javascript匿名函数中的'return function()'作用
Oct 15 Javascript
详解如何使用router-link对象方式传递参数?
May 02 Javascript
jQuery 更改checkbox的状态,无效的解决方法
Jul 22 #Javascript
Javascript字符串常用方法详解
Jul 21 #Javascript
jQuery实现鼠标经过购物车出现下拉框代码(推荐)
Jul 21 #Javascript
javascript实现滚动效果的数字时钟实例
Jul 21 #Javascript
如何用JS判断两个数字的大小
Jul 21 #Javascript
AngularJs基本特性解析(一)
Jul 21 #Javascript
jQuery表单验证插件解析(推荐)
Jul 21 #Javascript
You might like
了解咖啡雨林联盟认证 什么是雨林认证 雨林认证是什么意思
2021/03/05 新手入门
PHP实现批量检测网站是否能够正常打开的方法
2016/08/23 PHP
Thinkphp整合阿里云OSS图片上传实例代码
2019/04/28 PHP
封装了一个js图片轮换效果的函数
2011/09/28 Javascript
jquery自定义函数的多种方法
2014/01/09 Javascript
Bootstrap编写一个在当前网页弹出可关闭的对话框 非弹窗
2016/06/30 Javascript
Ionic2系列之使用DeepLinker实现指定页面URL
2016/11/21 Javascript
webpack实现热更新(实施同步刷新)
2017/07/28 Javascript
vue服务端渲染的实例代码
2017/08/28 Javascript
让网站自动生成章节目录索引的多个js代码
2018/01/07 Javascript
vue最简单的前后端交互示例详解
2018/10/11 Javascript
微信小程序实现保存图片到相册功能
2018/11/30 Javascript
js实现数字从零慢慢增加到指定数字示例
2019/11/07 Javascript
js实现百度淘宝搜索功能
2020/02/17 Javascript
JS中准确判断变量类型的方法
2020/06/01 Javascript
Vue如何基于vue-i18n实现多国语言兼容
2020/07/17 Javascript
[17:13]DOTA2 HEROS教学视频教你分分钟做大人-斯拉克
2014/06/13 DOTA
[01:01:43]EG vs VP 2018国际邀请赛淘汰赛BO3 第二场 8.24
2018/08/25 DOTA
浅谈function(函数)中的动态参数
2017/04/30 Python
python pandas 对时间序列文件处理的实例
2018/06/22 Python
对python多线程中Lock()与RLock()锁详解
2019/01/11 Python
python 实现查找文件并输出满足某一条件的数据项方法
2019/06/12 Python
Python定时任务工具之APScheduler使用方式
2019/07/24 Python
Spring @Enable模块驱动原理及使用实例
2020/06/23 Python
通过实例了解Python异常处理机制底层实现
2020/07/23 Python
Python 带星号(* 或 **)的函数参数详解
2021/02/23 Python
Dyson加拿大官方网站:购买戴森吸尘器,风扇,冷热器及配件
2016/10/26 全球购物
吉力贝官方网站:Jelly Belly
2019/03/11 全球购物
学习委员自我鉴定
2014/01/13 职场文书
师德师风建设方案
2014/05/08 职场文书
党支部反对四风思想汇报
2014/10/10 职场文书
六查六看自检自查剖析材料
2014/10/14 职场文书
群众路线教育实践活动学习心得体会
2014/10/30 职场文书
心术观后感
2015/06/11 职场文书
教你如何用python开发一款数字推盘小游戏
2021/04/14 Python
mysql使用FIND_IN_SET和group_concat两个方法查询上下级机构
2022/04/20 MySQL