原生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 相关文章推荐
jQuery 学习 几种常用方法
Jun 11 Javascript
javascript与CSS复习(三)
Jun 29 Javascript
Jquery插件 easyUI属性汇总
Jan 19 Javascript
jquery select 设置默认选中的示例代码
Feb 07 Javascript
node.js中的fs.symlinkSync方法使用说明
Dec 15 Javascript
深入理解JavaScript系列(26):设计模式之构造函数模式详解
Mar 03 Javascript
JS实现可拖曳、可关闭的弹窗效果
Sep 26 Javascript
基于jQuery实现鼠标点击导航菜单水波动画效果附源码下载
Jan 06 Javascript
JS监听滚动和id自动定位滚动
Dec 18 Javascript
JavaScript实现随机点名程序
Mar 25 Javascript
vue在响应头response中获取自定义headers操作
Jul 24 Javascript
element-ui和vue表单(对话框)验证提示语(残留)清除操作
Sep 11 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
PHP图片验证码制作实现分享(全)
2012/05/10 PHP
PHP中的类型提示(type hinting)功能介绍
2015/07/01 PHP
Laravel与CI框架中截取字符串函数
2016/05/08 PHP
PHP错误和异常处理功能模块示例
2016/11/12 PHP
PHP实现通过二维数组键值获取一维键名操作示例
2019/10/11 PHP
使用PHP开发留言板功能
2019/11/19 PHP
JavaScript中令你抓狂的魔术变量
2006/11/30 Javascript
jQuery下通过replace字符串替换实现大小图片切换
2012/05/22 Javascript
原生js实现查找/添加/删除/指定元素的class
2013/04/12 Javascript
js操作iframe兼容各种主流浏览器示例代码
2013/07/22 Javascript
js图片轮播特效代码分享
2015/09/07 Javascript
JavaScript使ifram跨域相互访问及与PHP通信的实例
2016/03/03 Javascript
JQuery 两种方法解决刚创建的元素遍历不到的问题
2016/04/13 Javascript
老生常谈JavaScript数组的用法
2016/06/10 Javascript
JavaScript省市区三级联动菜单效果
2016/09/21 Javascript
利用vue组件自定义v-model实现一个Tab组件方法示例
2017/12/06 Javascript
vue实现动态添加数据滚动条自动滚动到底部的示例代码
2018/07/06 Javascript
vue favicon设置以及动态修改favicon的方法
2018/12/21 Javascript
ES6中的class是如何实现的(附Babel编译的ES5代码详解)
2019/05/17 Javascript
javascript实现日历效果
2019/06/17 Javascript
python实现电子词典
2020/04/23 Python
Python中比较特别的除法运算和幂运算介绍
2015/04/05 Python
python如何通过实例方法名字调用方法
2018/03/21 Python
python+pandas生成指定日期和重采样的方法
2018/04/11 Python
解决Python安装后pip不能用的问题
2018/06/12 Python
tensorflow/core/platform/cpu_feature_guard.cc:140] Your CPU supports instructions that this T
2020/06/22 Python
Python容器类型公共方法总结
2020/08/19 Python
合同专员岗位职责
2013/12/18 职场文书
深入开展党的群众路线教育实践活动方案
2014/02/04 职场文书
中学生运动会入场词
2014/02/12 职场文书
春风行动实施方案
2014/03/28 职场文书
幼儿园小班个人总结
2015/02/12 职场文书
恰同学少年观后感
2015/06/08 职场文书
中秋节主题班会
2015/08/14 职场文书
成人成长感言如何写?
2019/08/16 职场文书
MySQL读取JSON转换的方式
2022/03/18 MySQL