JS实现会动的小车
2015-06-05怎么说呢,我想要实现的功能是很简单的,但是过程中,遇到不少问题。
我要实现的功能是页面右侧有辆小车,鼠标滚动或者拉动滚动条,小车消失,在底部点击“返还顶部”按钮后,页面缓慢向上滚动,同时小车出现,定位在屏幕底部不动,待页面滚动到顶部时,小车缓慢向上滑动(一开始是让小车匀速滑动的,后来加了个变速效果,让小车移动得更好看),制作一种动态效果。并且过程可重复进行。
div结构如下:
<div id="myAll" style="top:220px;">
<div id="myCar"><img id="myPhoto" src="http://www1.pcauto.com.cn/test/pcauto131219/test/up.png" widht="40px" height="56px"></div>
<div id="myText">
<p class="myXian">|</p>
<div class="myOwn">宝马92万起价居家必备</div>
</div>
</div>
其初始样式如下:
#myCar{width:40px;height:56px;position:absolute;right:0px;display:block;}
#myAll{width:45px;height:286px;position:absolute;top:220px;right:50px;display:block;text-align:center}
#myText{width:20px;height:230px;position:absolute;top:52px;right:10px;display:block;}
.myXian{text-align:center;background-color:white;line-height:10px;background-color: transparent;}
.myOwn{text-align:center;border:2px solid;border-radius:15px;background-color:red;}
(1)页面开始滚动,小车消失,很简单,代码如下:
window.onscroll=function(){
document.getElementById("myCar").style.position="fixed";
document.getElementById("myCar").style.display="none";
}
(2)在页面底部点击“返回顶部”按钮,页面缓慢向上滚动。“缓慢”,要求的是改变滚动条的速度,懵懂的我百度了一会,终于有了眉目。在页面滚动的同时,小车出现然后固定在页面上不动。利用timer=setInterval("runToTop()",5),让滚动条每次上移10px的距离,来达到减速的效果。
function runToTop(){
currentPosition=document.documentElement.scrollTop || document.body.scrollTop;
currentPosition-=10;
if(currentPosition>0)
{
window.scrollTo(0,currentPosition); //这里的0表示横坐标,currentPosition表示竖坐标
document.getElementById("myAll").style.top="500px";
document.getElementById("myAll").style.position="fixed";
document.getElementById("myAll").style.display="block";
}
}
(3)当滚动条到达最顶部的时候,小车要缓慢向上移动,创建动态的效果。
//代码接上面的if
else
{
setInterval(function(){
if(myTop>200){ //当小车从下往上移时与顶部的距离大于200时,小车持续上移
document.getElementById("myAll").style.top=myTop+"px";
document.getElementById("myAll").style.position="absolute";
document.getElementById("myAll").style.display="block";
myTop-=25; }} ,100);}
window.scrollTo(0,0); //currentPosition的值可能为负数,这时需要把页面滚到顶部
clearInterval(timer); //清除掉定时器,否则再次拉动滚动条向下的时候会有矛盾
}
(4)如果你觉得到此完成了任务,你就错了。执行程序之后,我发现其中存在冲突,在点击“返回顶部”,执行runToTop()方法的同时,window.onscroll方法也一起被执行了,这2个方法中小车的可见性(display属性值)是不同的,貌似window.onscroll的优先级比较高,掩盖掉了runTop()方法,导致小车并没有显示在页面上。后来,想到的解决方法是在window.onscroll方法中加入一个变量,适当改变它的值达到控制这个方法是否执行的目的。应用如下:
var isOk=true; //初始值
window.onscroll=function(){
if(isOk==true)
{
document.getElementById("myAll").style.position="fixed";
document.getElementById("myAll").style.display="none";
}
}
(5)到此,貌似差不多可以了,但是运行起来还是发现了bug:小车虽第一次可以正常滑动,但是第二次点击“返回顶部”按钮起,小车的情况就和第一次不同了,大概知道是runToTop()方法的逻辑有些问题。我调试程序发现,第二次之后,if(myTop>200){ }里的代码,始终没有执行,原来小车经过第一次运动之后,全局变量myTop已经小于200了,需要对值进行一个重新赋值:
myTop=500;//把mytop复原
timer=setInterval("runToTop()",5);
(6)最后还是有问题,纠结了很久,终于找到了原因,记得上面的代码中,我清掉了定时器timer吗(忘了烦请往回看看)?定时器timer中包含着一个让小车缓慢移动的定时器,删掉timer但是里面的子定时器还存在,导致小车运动速度过快,压根看不见了。解决方法,适时删除子定时器。
function myClick()
{
clearInterval(m); //此处需要清除上次所按“返回顶部”后设置的定时器
changeLenght=0.2;
changeLenght1=0.2;
myTop=500;//把mytop复原
timer=setInterval("runToTop()",5);
}
(7)小车移动采用了先加速,后减速的运动方式,最终的代码如下:
if(myTop>50)
{
m=setInterval(function(){ if(myTop>250){
document.getElementById("myAll").style.top=myTop+"px";
document.getElementById("myAll").style.position="absolute";
document.getElementById("myAll").style.display="block";
//不是匀速运动
//myTop-=1; myTop-=changeLenght;
//每次移动的距离增加0.02
changeLenght+=0.02;
}
//当车子离顶部的距离大于250时做加速运动,小于250时做减速运动
if(myTop<250&&myTop>50){
document.getElementById("myAll").style.top=myTop+"px";
document.getElementById("myAll").style.position="absolute";
document.getElementById("myAll").style.display="block"; myTop-=changeLenght;
//每次移动的距离减少0.02
changeLenght-=0.02;
}
}
,1);} //把开始动的时间减小就不会闪了
window.scrollTo(0,0);
clearInterval(timer);
isOk=true; //删除父定时器时,子的还在!!!!!!!!!!!!!!!!
}
程序终于正常运行了,做完不禁有点感叹,动手比较少,所以逻辑不够严谨,思路不够清晰。
JS实现会动的小车的更多相关文章
- D3.js 让图表动起来
D3 支持制作动态的图表.有时候,图表的变化需要缓慢的发生,以便于让用户看清楚变化的过程,也能给用户不小的友好感. 一.什么是动态效果 绘制完成后不再发生变化的,这是静态的图表. 动态的图表,是指图表 ...
- JS限制 获取动太ID,播放视频
JS限制textarea字数 function textdown(e) {textevent = e ; ) { return; } ) { alert("大侠,我手机屏幕小,先输入这么多字 ...
- 【js】插件—动效Velocity.js
Velocity.js——加速JavaScript动画 一款替代jQuery的$ .animate()动效的插件.兼容IE8和Android2.3及以上. 相比较优点: 1.它比JQuery更快,并实 ...
- JS特效@缓动框架封装及应用
| 版权声明:本文为博主原创文章,未经博主允许不得转载. 一.变量CSS样式属性获取/赋值方法 给属性赋值:(既能获取又能赋值) 1)div.style.width 单个赋值:点语法,这个方法比较固定 ...
- 利用velocity.js将svg动起来
关于velocity.js Velocity.js是一款jquery动画引擎插件,它拥有与jquery中的$.animate()相同的API,还打包了颜色动画,转换,循环,easing效果,类动画.滚 ...
- animation js控制 缓动效果
<!DOCTYPE html><html><head><meta charset="utf-8" /><title>缓动 ...
- js控制div动起来
代码: <html> <head> <title>让div动的测试</title> <script language="javascri ...
- JS实现缓动动画效果
原理如下: 假设要从数值A变化到数值B,如果是线性运动,则每次移动距离是一样:如果是缓动,每次移动距离不一样.那如何才能不一样呢?很简单,按比例移动就可以. 例如:每次移动剩余距离的一半. 对吧,超容 ...
- python + selenium + Js 处理轮动条
selenium并不是万能的,有时候页面上操作无法实现的,这时候就需要借助JS来完成了. 常见场景: 当页面上的元素超过一屏后,想操作屏幕下方的元素,是不能直接定位到,会报元素不可见的. 这时候需要借 ...
随机推荐
- linux下查看分区信息和剩余空间大小
1. 查看Linux系统分区信息,使用命令“fdisk -l” 2.使用命令”df -l和df -h“具体查看分区使用状况.实际这两个命令具有一样的作用区别是显示的容量单位不一样,当然也可以直接使用明 ...
- 模块mod_h323的编译
去h.323plus官网上下载关联的库 http://www.h323plus.org/source/ 很贴心,分操作系统下载,而且关联的ptlib库的版本也一并列了出来. 一.编译ptlib库 ex ...
- MySQL多表更新(逻辑外键/事实外键)
语法结构: UPDATE table_reference SET 列名1=value1[,列名2=value2,......] [WHERE where_condition] 说明: tabl ...
- 关于dom ready事件
0.加载完页面,解析完所有标签(不包括执行CSS和JS),并如规范中所说的设置 interactive 和执行每个静态的script标签中的JS,然后触发. 1.没有js,有css,有img,DOMC ...
- jQuery的.click,.bind,.unbind,.on,.off,.delegate,.undelegate
.click与.bind .click和.bind都是给每个元素绑定事件,对于只绑定一个click事件,.bind事件的简写就是.click那种方式. 这两种方式都会出现两个问题: 第一个问题,如果要 ...
- Android中利用SharedPreferences保存信息
package com.example.sharepreferen; import android.content.Context; import android.content.SharedPref ...
- Win7路由器设置过程
随着应用win7系统的人越来越多,对于这个系统的应用就更多了,其中大家最关注的就是这个系统和路由器上网的问题.下面,我们就来讲解一下win7系统的路由器的设置过程. 首先打开浏览器,在地址栏输入192 ...
- [转载] 每周推荐阅读 BFQ:实现IO的隔离共享与高吞吐访问
磁盘IO和网络IO隔离与共享是混部应用中基本需求,从早些年的BVC到现在的Matrix,以及Galaxy,或者未来的BS/Mint混部都遇到类似的问题:由于无法有效实现IO级的隔离(包括吞吐隔离.延时 ...
- nodejs学习笔记<二>简单的node服务器
在环境搭建好后,就可以开始动手架设(node驱动)一个简单的web服务器. 首先,nodejs还是用js编写.先来看一段node官网上的实例代码. var http = require('http') ...
- you don't have permission to view it 解决
the file couldn't be opened because you don't have permission to view it 简单设置下面的选项即可,不要谢我啊! change ...