JS完美运动框架【利用了Json】
- <!doctype html>
- <html>
- <head>
- <meta charset="utf-8">
- <title>完美运动框架</title>
- <style>
- body,ul,li{
- margin:0;
- padding:0;
- }
- ul,li{
- list-style:none;
- }
- ul li{
- width:200px;
- height:100px;
- background:yellow;
- margin-bottom:20px;
- border:4px solid #000;
- filter:alpha(opacity:30);
- opacity:0.3;
- }
- </style>
- <script src="move.js"></script>
- <script>
- window.onload = function(){
- var oLi = document.getElementById('li1');
- oLi.onmouseover = function(){
- startMove(oLi,{width:400,height:200,opacity:100});
- }
- oLi.onmouseout = function(){
- startMove(oLi,{width:200,height:100,opacity:30});
- }
- }
- </script>
- </head>
- <body>
- <ul>
- <li id = "li1">我是什么颜色</li>
- </ul>
- </body>
- </html>
move.js
- function getStyle(obj, attr)
- {
- if(obj.currentStyle)
- {
- return obj.currentStyle[attr];
- }
- else
- {
- return getComputedStyle(obj, false)[attr];
- }
- }
- function startMove(obj, json, fn)
- {
- clearInterval(obj.timer);
- obj.timer=setInterval(function (){
- flag=true;//定义标杆,假设所有运动都到达目标值
- for(var attr in json)
- {
- //1.取当前的值
- var iCur=0;
- if(attr=='opacity')
- {
- iCur=parseInt(parseFloat(getStyle(obj, attr))*100);
- }
- else
- {
- iCur=parseInt(getStyle(obj, attr));
- }
- //2.算速度
- var iSpeed=(json[attr]-iCur)/8;
- iSpeed=iSpeed>0?Math.ceil(iSpeed):Math.floor(iSpeed);
- //3.检测停止
- if(iCur!=json[attr])
- {
- flag=false;
- }
- if(attr=='opacity')
- {
- obj.style.filter='alpha(opacity:'+(iCur+iSpeed)+')';
- obj.style.opacity=(iCur+iSpeed)/100;
- }
- else
- {
- obj.style[attr]=iCur+iSpeed+'px';
- }
- }
- if(flag)
- {
- clearInterval(obj.timer);
- if(fn)
- {
- fn();
- }
- }
- }, 30)
- }
JS完美运动框架【利用了Json】的更多相关文章
- JS完美运动框架
这套框架实现了多物体,任意值,链式运动,多值运动,基本满足常见的需求. /* 功能:完美运动框架,可以实现多物体,任意值,链式运动,多值运动 版本:V1.0 兼容性:Chrome,FF,IE8+ (o ...
- js 完美运动框架
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JS 之完美运动框架
完美运动框架是对原来的任意值运动框架的改善和效率的提升,即利用了json对属性进行封装,从而提高效率: window.onload=function(){ var oDiv=document.getE ...
- 完美运动框架(js)
一.前言 学习js运动时,由于在实现多种不同运动效果过程中很多代码是重复的,故将其封装达到代码重用. 二.代码封装重用 function startMove(obj, json, fnEnd){ cl ...
- 【repost】JavaScript完美运动框架的进阶之旅
运动框架的实现思路 运动,其实就是在一段时间内改变left.right.width.height.opactiy的值,到达目的地之后停止. 现在按照以下步骤来进行我们的运动框架的封装: 匀速运动. 缓 ...
- JavaScript “完美运动框架”
/* “完美运动框架”,所谓“完美”,就是可以实现多个参数,多个物体运动互不影响的一个运动函数move(). * 大致结构如下:运动框架 EXP: move(obj,{width:200,height ...
- 2015.8.2js-19(完美运动框架)
/*完美运动框架*/ //1.先清除定时期,2,获取样式,如果是opacity则单独解决,3,定义速度,4,定义当前值是否到达目的地,5,判断当前值是否到达目的地,6运动基本,如果是opacity f ...
- Javascript 完美运动框架——逐行分析代码,让你轻松了解运动的原理
大家一听这名字就知道,有了这套框架 网上的效果基本都是可以实现的.实际上之前的运动框架还是有局限性的,就是不能让好几个值一块运动. 那这个问题怎么解决呢? 我们先来看看之前的运动框架 function ...
- 纯js写“运动”框架
所谓“运动”不一定真的是运动,在连续的一段时间内改变某一样式都可以成为“运动”. 先写几个会用到的函数 //获取某一元素的指定样式 function getstyle (element, target ...
随机推荐
- NX二次开发-算法篇-判断找到两个数组里不相同的对象
NX9+VS2012 #include <uf.h> #include <uf_curve.h> #include <uf_modl.h> #include < ...
- C++ string的大小写转换【转载】
转载自https://www.cnblogs.com/balingybj/p/4678850.html 将一个string转换成大写或者小写,是项目中经常需要做的事情,但string类里并 没有提供这 ...
- iOS13适配/黑暗模式的适配/KVC访问私有属性/模态弹窗ViewController 默认样式改变 /LaunchImage即将废弃/蓝牙的权限申请/推送Device Token适配/UIKit 控件变化/StatusBar新增样式
目录 1. KVC访问私有属性 2. 模态弹窗ViewController 默认样式改变 3. 黑暗模式的适配 4. LaunchImage即将废弃 5. 新增一直使用蓝牙的权限申请 6. Sign ...
- mysql查看数据库大小或者表大小
要想知道每个数据库的大小的话,步骤如下: 1.进入information_schema 数据库(存放了数据库的信息) use information_schema; 2.查询所有数据库的大小: sel ...
- [kuangbin带你飞]专题一 简单搜索 - N - Find a way
正确代码: #include<iostream> #include<queue> #define N 210 #define inf 0xffffff using namesp ...
- codeforces round#524 D - Olya and magical square /// 大概算是数学规律题?
题目大意: t 个测试用例 (1≤t≤103) 给定n k (1≤n≤10^9,1≤k≤10^18) 表示有一个边长为2^n的正方形格子 每次操作只能将一个格子切割为左上左下右上右下的四等分格子 ...
- 【POJ】3259 Wormholes
题目链接:http://poj.org/problem?id=3259 题意:n个农场,m条双向路径,w条单向路径(虫洞).单向虫洞路径是负值.农夫想知道自己能不能看到自己(X). 题解:其实刚开始没 ...
- linux下使用自带mail发送邮件
linux下使用自带mail发送邮件 mailx工具说明: linux可以通过安装mailx工具,mailx是一个小型的邮件发送程序,一般可以通过该程序在linux系统上,进行监控linux系统状态并 ...
- List<> ,string[]和string的相互转换
1.string转换成string[]数组 string str = "aaa,bbb,ccc,dddd"; string[] strs = str.Split(','); 2.s ...
- 安装Epson打印机但因lsb依赖错误而中断的驱动程序
sudo apt-get install printer-driver-escpr 安装Epson打印机但因lsb依赖错误而中断的驱动程序 问题: 我正在安装 Epson XP-310 驱动程序,从这 ...