js回调函数仿360开机


Posted in Javascript onDecember 26, 2019

本文实例为大家分享了js回调函数仿360开机的具体代码,供大家参考,具体内容如下

<!DOCTYPE html>
<html>
<head lang="en">
  <meta charset="UTF-8">
  <title></title>
  <style>
    #demo{
      width: 322px;  /*不设高,因为下面的盒子消失之后,上面的盒子立刻掉下来*/
      position: fixed;
      bottom:0;
      right:0;
    }
    span{
      position: absolute;
      top:0;
      right:0;
      width:30px;
      height: 20px;
      cursor: pointer;
    }
  </style>
</head>
<body>
<div id="demo">
  <span id="close"></span> <!--盒子右上角的x号区域-->
  <div id="shang">
    <img src="t.jpg" alt=""/>
  </div>
  <div id="xia">
    <img src="b.jpg" alt=""/>
  </div>
</div>
</body>
</html>
<script>
   function $id(id){return document.getElementById(id);}
   var demo=$id("demo");
   var shang=$id("shang");
   var xia=$id("xia");
   var close=$id("close"); //注意:不能直接用span.onclick,因为span是div的子元素,点击span的时候,发生了事件冒泡,响应在了父元素div上,所以对onclick事件的响应元素是父元素div
   close.onclick=function () {
       run(xia,{height:0},function () { //仿360开机:点击关闭区域时,首先下面的盒子高度变为0,之后整个大盒子宽度变成0,依次消失
         run(demo,{width:0}) //这里使用了回调函数
       })
   }
 
  //封装运动框架基本函数(多个属性)
  function run(obj,json,fn) {
    clearInterval(obj.timer);
    obj.timer=setInterval(function () {
      var flag=true; //用来判断定时器是否停止,一定写在遍历的外面,否则一遍历就true
      for( attr in json)
      {
        var cstyle=parseInt(getStyle(obj,attr)); //获得当前属性
        var step=(json[attr]-cstyle)/10; //计算步长
        step=step>0 ? Math.ceil(step) : Math.floor(step);
        obj.style[attr]=cstyle+step+"px";
 
        if(cstyle!=json[attr]) //在遍历中,只要有一个属性值没到达目标位置,定时器就不能停
        {
          flag=false;
        }
      }
 
      if(flag) //遍历完了之后,flag是true,所有的值都到达目标位置了,停止定时器
      {
        clearInterval(obj.timer);
        if(fn) //回调函数,定时器关闭之后,如果有fn,执行fn()
        {
          fn();
        }
      }
    },30)
  }
 
  //返回当前样式的函数
  function getStyle(obj,attr) //返回谁的,哪个属性
  {
    if(obj.currrentStyle)
    {
      return obj.currentStyle[attr];
    }
    else{
      return window.getComputedStyle(obj,null)[attr]; //w3c浏览器
    }
  }
 
</script>

js回调函数仿360开机

关键代码:

1、demo(最外面整个大盒子)的定位

固定定位,放在页面的右下方 

span(关闭按钮)绝对定位在demo的右上方:

#demo{
  width:322px;
  position : fixed;
  bottom:0;
  right:0;
} 
span{
width:30px;

height: 20px;

position:absolute;

top:0;

right:0;

cursor:pointer;
}

2、防止冒泡,因为span(关闭按钮)的父元素是demo, 所以不能直接写 span.onclick , 这样会发生冒泡,相当于点击了父元素demo, 事件会响应在父元素上,所以应该用span的 id 绑定事件

3、回调函数,点击关闭按钮时,首先下面的盒子 高度变成 0 ,然后整个盒子的宽度 变成 0,依次消失 (所以一开始demo 的高度不应该设置,因为下面的盒子消失之后,上面的盒子会掉下来)  回调函数写的位置:定时器结束的位置

close.onclick=function(){
  run(xia, {height:0}, function(){
    run(shang,{demo:0}
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
分享14个很酷的jQuery导航菜单插件
Apr 25 Javascript
表单切换,用回车键替换Tab健(不支持IE)
Jul 20 Javascript
JS和JQUERY获取页面大小,滚动条位置,元素位置(示例代码)
Dec 14 Javascript
js 实现浏览历史记录示例
Apr 20 Javascript
JavaScript判断变量是否为数组的方法(Array)
Feb 24 Javascript
Vuex简单入门
Apr 19 Javascript
angular2 ng2 @input和@output理解及示例
Oct 10 Javascript
element ui 对话框el-dialog关闭事件详解
Feb 26 Javascript
详解Vue-cli中的静态资源管理(src/assets和static/的区别)
Jun 19 Javascript
如何从零开始手写Koa2框架
Mar 22 Javascript
js实现消灭星星(web简易版)
Mar 24 Javascript
使用react+redux实现计数器功能及遇到问题
Jun 02 Javascript
js仿360开机效果
Dec 26 #Javascript
element-ui中按需引入的实现
Dec 25 #Javascript
原生JS实现顶部导航栏显示按钮+搜索框功能
Dec 25 #Javascript
jQuery+PHP+Ajax实现动态数字统计展示功能
Dec 25 #jQuery
解决Vue 刷新页面导航显示高亮位置不对问题
Dec 25 #Javascript
Vue 路由间跳转和新开窗口的方式(query、params)
Dec 25 #Javascript
如何基于JS截获动态代码
Dec 25 #Javascript
You might like
Destoon旺旺无法正常显示,点击提示“会员名不存在”的解决办法
2014/06/21 PHP
Yii2增加验证码步骤详解
2016/04/25 PHP
PHP实现微信模拟登陆并给用户发送消息的方法【文字,图片,图文】
2017/06/29 PHP
PHP实现基于图的深度优先遍历输出1,2,3...n的全排列功能
2017/11/10 PHP
php中的依赖注入实例详解
2019/08/14 PHP
Javascript常用小技巧汇总
2015/06/24 Javascript
jQuery实现自定义checkbox和radio样式
2015/07/13 Javascript
require.js的用法详解
2015/10/20 Javascript
开启Javascript中apply、call、bind的用法之旅模式
2015/10/28 Javascript
JS模仿手机端九宫格登录功能实现代码
2016/04/28 Javascript
ASP.NET jquery ajax传递参数的实例
2016/11/02 Javascript
ES6解构赋值的功能与用途实例分析
2017/10/31 Javascript
jQuery实现使用sort方法对json数据排序的方法
2018/04/17 jQuery
vue通过滚动行为实现从列表到详情,返回列表原位置的方法
2018/08/31 Javascript
利用Python为iOS10生成图标和截屏
2016/09/24 Python
在 Python 应用中使用 MongoDB的方法
2017/01/05 Python
Python 查找字符在字符串中的位置实例
2018/05/02 Python
Python实现的个人所得税计算器示例
2018/06/01 Python
深入flask之异步非堵塞实现代码示例
2018/07/31 Python
python 接口实现 供第三方调用的例子
2019/08/13 Python
Python实现直播推流效果
2019/11/26 Python
使用wxpy实现自动发送微信消息功能
2020/02/28 Python
Python pysnmp使用方法及代码实例
2020/08/24 Python
解决Ubuntu18中的pycharm不能调用tensorflow-gpu的问题
2020/09/17 Python
如何用python批量调整视频声音
2020/12/22 Python
汽车检测与维修应届毕业生求职信
2013/10/19 职场文书
电子商务专业应届毕业生求职信
2014/06/21 职场文书
领导班子作风建设年个人整改措施
2014/09/29 职场文书
安装工程师岗位职责
2015/02/13 职场文书
2015年店长工作总结范文
2015/04/08 职场文书
确保工程质量承诺书
2015/04/29 职场文书
幼儿园卫生保健制度
2015/08/05 职场文书
上班旷工检讨书
2015/08/15 职场文书
2016拓展训练心得体会范文
2016/01/12 职场文书
2016年小学感恩节活动总结
2016/04/01 职场文书
vue代码分块和懒加载非必要资源文件
2022/04/11 Vue.js