js之运动框架缓冲运动

由于JS里对于数值小数点会自动去除,所以对于运动位置,需要使用Math.ceil()向上取整或者

Math.floor()向下取整进行解决

以下是我的缓冲运动练习简单代码

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style>
#div1{width:200px;height:200px;background:red;left:0px;top:50px;position:absolute;}
#div2{width:1px;height:250px;background:black;left:400px;top:20px;position:absolute;}
</style>
<script>
window.onload=function ()
{
	var oDiv=document.getElementById(‘div1‘);
	var oBtn=document.getElementById(‘btn1‘);
	oBtn.onclick=function ()
	{
		startMove(400);	

	}
};
var timer=null;
function startMove(target)
{
	var oDiv=document.getElementById(‘div1‘);
	var speed=0;
	clearInterval(timer)

	timer=setInterval(function ()
	{
			//speed会被直接取整,舍去余数,所以位置不精确,需要通过向上取整Math.ceil()来解决
			speed=Math.ceil((target-oDiv.offsetLeft)/10);   
			oDiv.style.left=oDiv.offsetLeft+speed+‘px‘;
			document.title=oDiv.offsetLeft+‘,‘+speed;
	},30);
};
</script>
</head>

<body>
<input id="btn1" type="button" value="开始运动" />
<div id="div1">
</div>
<div id="div2">
</div>
</body>
</html>
时间: 2024-10-25 05:00:07

js之运动框架缓冲运动的相关文章

(39)JS运动之缓冲运动

基本思路:使用定时器让物体向右运动,在运动的过程中再不是匀速运动,而是先快后慢,即距离越大,速度越快,距离越小,速度越小,可是到达终点的时候,必须注意要使用向上取整函数Math.ceil()和向下取整函数Math.floor();这样才可以正确无误地到达终点,而不是有出入. <!DOCTYPE HTML> <!-- --> <html> <head> <meta charset="utf-8"> <title>&l

JS小问题之——缓冲运动

今天写一个实现动画缓冲的效果,源代码用到了一个小技巧,之前觉得并没有什么用,后来觉得还是很有必要的,贴上来记录一下. 代码如下: //图片切换,淡入淡出效果 function show(a){ index=a for(i=0;i<onum.length;i++)onum[i].className=""; onum[index].className="current"; clearInterval(timer); console.log(oimg[0].offs

JS运动基础(二) 摩擦运动、缓冲运动

position:static(静态定位) 当position属性定义为static时,可以将元素定义为静态位置,所谓静态位置就是各个元素在HTML文档流中应有的位置 podisition定位问题.所以当没有定义position属性时,并不说明该元素没有自己的位置,它会遵循默认显示为静态位置,在静态定位状态下无法通过坐标值(top,left,right,bottom)来改变它的位置. position:absolute(绝对定位) 当position属性定义为absolute时,元素会脱离文档流

js运动框架逐渐递进版

运动,其实就是在一段时间内改变left.right.width.height.opactiy的值,到达目的地之后停止. 现在按照以下步骤来进行我们的运动框架的封装: 匀速运动. 缓冲运动. 多物体运动. 任意值变化. 链式运动. 同时运动 (第一部分):匀速运动 运动基础 思考:如何让div动起来?如下: 设置元素为绝对定位,只有绝对定位后,left,top等值才生效. 定时器的使用(动态改变值),这里使用setInterval()每隔指定的时间执行代码. 计时器setInterval(函数,交

JS实现多物体width缓冲运动实例

多物体运动,运动参数不能公用. 这篇文章主要介绍了JS实现多物体缓冲运动实例代码,有需要的朋友可以参考一下 效果: 思路: 利用setInterval计时器进行运动,offsetWidth实现宽度的变动,在用onmouseover将终点和所选中的DIV放入参数再进行缓冲运动. 代码: 代码如下: <head runat="server"> <title></title> <style type="text/css">

(43)JS运动之链式运动框架

链式运动框架就是一系列的运动分阶段进行,在普通的运动框架上加上一个參数function,这个function表示下一个要运行的动作.详细代码例如以下: <!DOCTYPE HTML> <!--链式运动框架:运动分阶段进行,当运动停止的时候.运行下一个运动--> <html> <head> <meta charset="utf-8"> <title></title> <style> #div1

JavaScript 基础入门11 - 运动框架的封装

目录 JavaScript 运动原理 运动基础 简单运动的封装 淡入淡出 不同属性的设置 多属性值同时运动 运动回调,链式运动 缓冲运动 加入缓冲的运动框架 JavaScript 运动原理 运动基础 在JavaScript中,如何让一个页面元素动起来? 首先,我们需要了解的是,在JavaScript中如何让一个页面元素动起来. 我们先来实现一个简单的功能,当我们点击按钮之后,让一个元素动起来.并且到达500的边界之后立刻停止下来. <!DOCTYPE html> <html> &l

运动框架

完美运动框架,包括有style和opacity的样式实现 //以下是运动框架的内容 function getStyle(obj, name) { if(obj.currentStyle) //仅IE { return obj.currentStyle[name]; } else //兼容FF浏览器 { return getComputedStyle(obj, false)[name]; } } function startMove(obj,json,fnEnd)//比普通的运动框架写多了一个函数

js--链式缓冲运动框架

这些框架都是鄙人自学的网上视频,至于是哪家,想必大家都知道的,当然不纠结这个,最主要的是学习的过程和结果,甚至于你理解,掌握了没有 网上有很多的开源框架,很佩服他们的思路和写法,或许这就是代码之美吧 我一个小小的前台,做界面的,现在也要去学习设计思路了,毕竟你拿工资的多少和你掌握技能的多少.深度是成正比的 当然更要相信 努力必有回报,坚持一定成功 以下是更新的学习运动框架的进度和代码 更新时间:2014-12-11 js框架---缓冲链式运动--已经掌握 1 //运动框架 2 //author: