原生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 日期处理之时区问题
Oct 08 Javascript
jQuery AJAX实现调用页面后台方法和web服务定义的方法分享
Mar 01 Javascript
jquery ui对话框实例代码
May 10 Javascript
iframe的onreadystatechange事件在firefox下的使用
Apr 16 Javascript
jQuery绑定事件-多种实现方式总结
May 09 Javascript
JS中Swiper的使用和轮播图效果
Aug 11 Javascript
angular将html代码输出为内容的实例
Sep 30 Javascript
vue-cli 2.*中导入公共less文件的方法步骤
Nov 22 Javascript
bootstrap table实现iview固定列的效果实例代码详解
Sep 30 Javascript
小程序自定义模板实现吸顶功能
Jan 08 Javascript
Vue表单控件数据绑定方法详解
Feb 05 Javascript
小程序富文本提取图片可放大缩小
May 26 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
详解js异步文件加载器
2016/01/24 PHP
PHP微信开发用Cache 解决数据缓存
2016/07/11 PHP
smarty循环嵌套用法示例分析
2016/07/19 PHP
PHP简单留言本功能实现代码
2017/06/09 PHP
TP5框架实现上传多张图片的方法分析
2020/03/29 PHP
Gird事件机制初级读本
2007/03/10 Javascript
Jquery 滑入滑出效果实现代码
2010/03/27 Javascript
统计出现最多的字符次数的js代码
2010/12/03 Javascript
JS面向对象编程浅析
2011/08/28 Javascript
THREE.JS入门教程(4)创建粒子系统
2013/01/24 Javascript
多个表单中如何获得这个文件上传的网址实现js代码
2013/03/25 Javascript
基于Jquery+div+css实现弹出登录窗口(代码超简单)
2015/10/27 Javascript
nodejs基础应用
2017/02/03 NodeJs
D3.js中强制异步文件读取同步的几种方法
2017/02/06 Javascript
jQuery插件echarts实现的循环生成图效果示例【附demo源码下载】
2017/03/04 Javascript
微信小程序 侧滑删除(左滑删除)
2017/05/23 Javascript
基于datepicker定义自己的angular时间组件的示例
2018/03/14 Javascript
vue 自定义指令自动获取文本框焦点的方法
2018/08/25 Javascript
vue通过style或者class改变样式的实例代码
2018/10/30 Javascript
解决微信小程序调用moveToLocation失效问题【超简单】
2019/04/12 Javascript
openlayers4.6.5实现距离量测和面积量测
2020/09/25 Javascript
[00:59]PWL开团时刻DAY7——我在赶
2020/11/06 DOTA
Python输出PowerPoint(ppt)文件中全部文字信息的方法
2015/04/28 Python
Python选课系统开发程序
2016/09/02 Python
python实现的正则表达式功能入门教程【经典】
2017/06/05 Python
Python设计模式之模板方法模式实例详解
2019/01/17 Python
python 阶乘累加和的实例
2019/02/01 Python
Python 简单计算要求形状面积的实例
2020/01/18 Python
使用python检查yaml配置文件是否符合要求
2020/04/09 Python
Python使用Excel将数据写入多个sheet
2020/05/16 Python
python创建文本文件的简单方法
2020/08/30 Python
澳大利亚窗帘商店:Curtain Wonderland
2019/12/01 全球购物
科技活动周标语
2014/10/08 职场文书
2015年店长工作总结范文
2015/04/08 职场文书
解决Navicat for MySQL 连接 MySQL 报2005错误的问题
2021/05/29 MySQL
使用python+pygame开发消消乐游戏附完整源码
2021/06/10 Python