JS实现滑动门效果的方法详解


Posted in Javascript onDecember 19, 2016

本文实例讲述了JS实现滑动门效果的方法。分享给大家供大家参考,具体如下:

描述:鼠标移动到一副图片上,会显示该副图片的全貌,而其他图片会显示概貌,效果图如下:

JS实现滑动门效果的方法详解

一、没有动画效果的运动

思路:

1.定好每张图片的初始位置(第一张完全显示,234只露出一部分)
2.计算每道门的移动距离(即未显露的部分)
3.绑定鼠标滑过事件

window.onload=function(){
  var box=document.getElementById("box");
  var img=box.getElementsByTagName("img");
  //单张图片宽度
  var imgWidth=img[0].offsetWidth;
  //露出的宽度
  var exposeWidth=160;
  //设置容器总宽度
  var boxWidth=imgWidth+exposeWidth*(img.length-1)
  box.style.width=boxWidth+"px";
  //设置图片初始位置
  function setImgspos(){
    for(var i=1,len=img.length;i<len;i++){ //len在for循环的初始化语句里先定义好,这样就不需要每次都计算img的个数了,比for(var i=1;i<img.length;i++)性能高
      img[i].style.left=imgWidth+exposeWidth*(i-1)+"px";
    }
  }
  setImgspos();
  //计算每道门打开时应移动的距离
  var translate=imgWidth-exposeWidth;
  for(var i=0,len=img.length;i<len;i++){
    (function(i){ //这里为什么需要匿名函数?(简单来说是函数变量作用域的问题)img[i].onmouseover=function(){}这个函数内部使用了变量i,但是i没有定义,于是向外查找,找到for循环里定义的i,点击事件是for循环执行完毕后才开始执行的,即此时i=4,所以会报错img[i]没有定义,这里加一层匿名函数相当于闭包处理,i以形参的方式传递给内层函数
      img[i].onmouseover=function(){
        setImgspos(); //每次移上去先重置位置
        for(var j=1;j<=i;j++){ //第二个循环体作用:可能会移多道门(比如放到第三道门上,二和三都要动,不是只动三,另外第一道门永远不动)
          img[j].style.left=parseInt(img[j].style.left)-translate+"px";
        }
      };
    })(i); //这个i是实参
  }
};

二、展开加速、收拢减速的运动

注意:设置每道门初始位置时,不需要在写一个function了,因为要分别写打开和关闭动画,会造成一个卡顿,瞬间闪烁。

思路:

1.需要鼠标滑过这道门的初始位置
2.需要鼠标滑过这道门的结尾位置
3.需要一个速度和定时器来完成缓缓移动的过程

window.onload=function(){
  var box=document.getElementById("box");
  var img=box.getElementsByTagName("img");
  //单张图片宽度
  var imgWidth=img[0].offsetWidth;
  //露出的宽度
  var exposeWidth=160;
  //设置容器总宽度
  var boxWidth=imgWidth+exposeWidth*(img.length-1)
  box.style.width=boxWidth+"px";
  //设置图片初始位置
  for(var i=1,len=img.length;i<len;i++){
    img[i].pos=img[i].style.left=imgWidth+exposeWidth*(i-1)+"px";
  }
  function openDoor(el,translate){
    var begin=parseInt(el.pos);
    var end=begin-translate;
    var iSpeed=10;
    setTimeout(function(){
      el.style.left=parseInt(el.style.left)-iSpeed+"px"; //为什么不用begin?每次的初始位置会变
      iSpeed*=1.5;  //没有这句话就是匀速运动
      if(parseInt(el.style.left)<=end){
        el.style.left=end+"px";
      }else{
        setTimeout(arguments.callee,25); //定时器有名字可以直接调用,没名字,就用原生js方法arguments.callee
      }
    },25);
  };
  function closeDoor(el,translate){
    var begin=parseInt(el.pos)-translate; //关门默认情况是张开的
    var end=begin+translate; //这里可以直接写var end=parseInt(el.pos);
    var iSpeed=100;
    setTimeout(function(){
      el.style.left=parseInt(el.style.left)+iSpeed+"px"; //为什么不用begin?每次的初始位置会变
      iSpeed=Math.ceil(iSpeed*0.7); //没有这句话就是匀速运动
      if(parseInt(el.style.left)>=end){
        el.style.left=end+"px";
      }else{
        setTimeout(arguments.callee,25); //定时器有名字可以直接调用,没名字,就用原生js方法arguments.callee
      }
    },25);
  };
  var translate=imgWidth-exposeWidth;
  for(var i=0,len=img.length;i<len;i++){
    (function(i){
      img[i].onmouseover=function(){
        //开门 自己和自己左边的全部循环到
        for(var j=1;j<=i;j++){
          openDoor(img[j],translate);
        }
        //关门 自己右边的全部循环到
        for(var j=i+1;j<img.length;j++){
          closeDoor(img[j],translate);
        }
      };
    })(i);
  }
};

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JQuery 学习笔记 选择器之五
Jul 23 Javascript
事件绑定之小测试  onclick &amp;&amp; addEventListener
Jul 31 Javascript
node.js中的buffer.Buffer.isBuffer方法使用说明
Dec 14 Javascript
原生JavaScript实现动态省市县三级联动下拉框菜单实例代码
Feb 03 Javascript
Angular2表单自定义验证器的实现
Oct 19 Javascript
AngularJS中transclude用法详解
Nov 03 Javascript
Bootstrap3 datetimepicker控件使用实例
Dec 13 Javascript
Vue不能检测到Object/Array更新的情况的解决
Jun 26 Javascript
vue项目打包部署_nginx代理访问方法详解
Sep 20 Javascript
react配置antd按需加载的使用
Feb 11 Javascript
js简单的分页器插件代码实例
Sep 11 Javascript
JS判断数组四种实现方法详解
Jun 29 Javascript
jQuery纵向导航菜单效果实现方法
Dec 19 #Javascript
简单理解js的冒泡排序
Dec 19 #Javascript
JS瀑布流实现方法实例分析
Dec 19 #Javascript
移动端日期插件Mobiscroll.js使用详解
Dec 19 #Javascript
JavaScript闭包和范围实例详解
Dec 19 #Javascript
JS前端笔试题分析
Dec 19 #Javascript
利用vue实现模态框组件
Dec 19 #Javascript
You might like
日本十大科幻动漫 宇宙骑士垫底,第一已成经典
2020/03/04 日漫
学习discuz php 引入文件的方法DISCUZ_ROOT
2009/06/21 PHP
一组PHP可逆加密解密算法实例代码
2014/01/21 PHP
php实现的递归提成方案实例
2015/11/14 PHP
清除网页历史记录,屏蔽后退按钮!
2008/12/22 Javascript
jQuery 第二课 操作包装集元素代码
2010/03/14 Javascript
基于jquery的cookie的用法
2011/01/10 Javascript
你必须知道的Javascript知识点之&quot;单线程事件驱动&quot;的使用
2013/04/23 Javascript
javascript级联下拉列表实例代码(自写)
2013/05/10 Javascript
js跨域访问示例(客户端/服务端)
2014/05/19 Javascript
jquery动态调整div大小使其宽度始终为浏览器宽度
2014/06/06 Javascript
深入理解Angular2 模板语法
2016/08/07 Javascript
深入理解Node中的buffer模块
2017/06/03 Javascript
vue开发调试神器vue-devtools使用详解
2017/07/13 Javascript
JsChart组件使用详解
2018/03/04 Javascript
layui监听工具栏的实例(操作列表按钮)
2019/09/10 Javascript
原生JS实现顶部导航栏显示按钮+搜索框功能
2019/12/25 Javascript
在react项目中使用antd的form组件,动态设置input框的值
2020/10/24 Javascript
Python isinstance函数介绍
2015/04/14 Python
python读取文本绘制动态速度曲线
2018/06/21 Python
python用post访问restful服务接口的方法
2018/12/07 Python
Python 移动光标位置的方法
2019/01/20 Python
Python利用Scrapy框架爬取豆瓣电影示例
2020/01/17 Python
Window系统下Python如何安装OpenCV库
2020/03/05 Python
TensorFlow的reshape操作 tf.reshape的实现
2020/04/19 Python
Django框架配置mysql数据库实现过程
2020/04/22 Python
Python实现CAN报文转换工具教程
2020/05/05 Python
CSS3 选择器 基本选择器介绍
2012/01/21 HTML / CSS
Html5移动端弹幕动画实现示例代码
2018/08/27 HTML / CSS
医学生实习自荐信
2013/10/01 职场文书
综合实践教学反思
2014/01/31 职场文书
工程专业应届生求职信
2014/02/19 职场文书
工作时间调整通知
2015/04/24 职场文书
国家助学贷款承诺书
2015/04/30 职场文书
如何用JavaScript实现一个数组惰性求值库
2021/05/05 Javascript
JavaScript中document.activeELement焦点元素介绍
2021/11/27 Javascript