JavaScript初探之——图片移动
在我们打开页面的时候我们看到的大部分页面都是动态的,曾经学习VB的时候要实现一些动态的画面第一个想到的就是用Flash,如今学习了BS的东西,才算是开眼界了,刚刚学习了一个动画的效果,给大家展示一下。一个小小的函数,却实现了让页面动起来的效果。
在非常多的时候。我们为了实现一一些效果,比方渐变。移动。假设用Flash的画,无疑为浏览器加入了太大的负载,假设用多张图片一张一张显示的画。这样做又太死板了,不利于我们的变化,所以最好的方法还是封装一个方法,让我们的图片依据我们想要的效果移动。同一时候运用面向对象的方法来实现。也就是分装一个方法。我们仅仅须要设置參数就能够实现我们想要的方法的移动,是不是非常方便了,废话不多说,代码加上
//设置动画
Base.prototype.animate = function (obj) {
for (var i = 0; i < this.elements.length; i ++) {
var element = this.elements[i];
//长高变换动画。仅仅要增加 width 和 height 值就可以。
var attr = obj['attr'] == 'x' ? 'left' : obj['attr'] == 'y' ? 'top' :
obj['attr'] == 'w' ? 'width' : obj['attr'] == 'h' ? 'height' : 'left'; var start = obj['start'] != undefined ? obj['start'] : getStyle(element, attr); //可选,默认是CSS的起始位置
var t = obj['t'] != undefined ? obj['t'] : 30; //可选,默认30毫秒运行一次
var step = obj['step'] != undefined ? obj['step'] : 10; //可选。每次运行10像素 //提供 alter 增量和 target 目标量两种方案
var alter = obj['alter'];
var target = obj['target']; //缓冲运动
var speed = obj['speed'] != undefined ? obj['speed'] : 6; //可选,默认缓冲速度为6
var type = obj['type'] == 0 ? 'constant' : obj['type'] == 1 ? 'buffer' : 'buffer'; //可选,0表示匀速,1表示缓冲,默认缓冲 if (alter != undefined && target == undefined) {
target = alter + start;
} else if (alter == undefined && target == undefined) {
throw new Error('alter增量或target目标量必须传一个!');
} if (start > target) step = -step;
element.style[attr] = start + 'px';
clearInterval(window.timer);
timer = setInterval(function () {
//正值的使用 Math.ceil 取整,小数部分进一位。 负值的时候使用 Math.floor,小数部分进一位。 这样就不会导致结束运动的时候不流畅突兀的感觉。
if (type == 'buffer') {
step = (target - getStyle(element, attr)) / speed;
step = step > 0 ? Math.ceil(step) : Math.floor(step);
} */
//更好的解决多出几个像素或少出几个像素的方法
if (step == 0) {
setTarget();
} else if (step > 0 && Math.abs(getStyle(element, attr) - target) <= step) {
setTarget();
} else if (step < 0 && (getStyle(element, attr) - target) <= Math.abs(step)) {
setTarget();
} else {
//放在else永远不会和停止运动通知运行,就不会出现303同一时候剪到300的问题
//可是会出现不同一时候剪到300的问题,导致突兀
element.style[attr] = getStyle(element, attr) + step + 'px';
} document.getElementById('aaa').innerHTML += getStyle(element, attr) + '<br />';
}, t); function setTarget() {
element.style[attr] = target + 'px';
clearInterval(timer);
}
}
return this;
};
<span style="white-space:pre"> </span>函数调用
$(function () {
$('#button').click(function () {
$('#box').animate({
'attr' : 'x',
'start' : 100,
'alter' : 50,
'target' : 0,
'step' : 7
});
});
});
HTML代码。我们仅仅须要设置一个ID就能够了,也就是在body找那个加入例如以下代码就可以
<div id="box">box</div> <input type="button" id="button" value="按钮" />
<div id="aaa"></div>
初次学习javaScript,感觉他真非常的奇妙。曾经学习HTML的时候。静态的网页是能够的,可是小相对于JavaScript,他更像是一个面向过程,须要什么,都是一步一步的来结局,而JavaScript更像是面向对象,把一些方法非常好的进行封装,从而更好的运用。难怪会叫JavaScript。有个Java的单词还真有点面向对象的意思。
JavaScript初探之——图片移动的更多相关文章
- JavaScript学习(一) —— 环境搭建与JavaScript初探
1.开发环境搭建 本系列教程的开发工具,我们采用HBuilder. 可以去网上下载最新的版本,然后解压一下就能直接用了.学习JavaScript,环境搭建是非常简单的,或者说,只要你有一个浏览器,一个 ...
- 用javascript协助导入图片
用javascript协助导入图片 需求 先说说需求.春节回家见爸妈,老爸迷上了摄影.他把平时的照片都上传到了 成都图片网, 这个成都图片网专门有一个 "快拍成都" 的版块,用于大 ...
- 每天一个JavaScript实例-推断图片是否载入完毕
<!doctype html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- JavaScript修改Canvas图片
用JavaScript修改Canvas图片的分辨率(DPI) 应用场景: 仓库每次发货需要打印标签, Canvas根据从数据库读取的产品信息可以生成标签JPG, 但是这个JPG图片的默认分辨率(D ...
- javascript仿新浪微博图片放大缩小及旋转效果
javascript仿新浪微博图片放大缩小及旋转效果 经常看到新浪微博里有图片放大缩小旋转效果,感觉效果还不错,所以就想试着做一个类似的demo出来,至于旋转对于IE可以用滤镜来解决,标准的浏览器可以 ...
- JavaScript实现判断图片是否加载完成的3种方法整理
JavaScript实现判断图片是否加载完成的3种方法整理 有时候我们在前端开发工作中为了获取图片的信息,需要在图片加载完成后才可以正确的获取到图片的大小尺寸,并且执行相应的回调函数使图片产生某种显示 ...
- 特殊例子--JavaScript代码实现图片循环滚动效果
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JavaScript初探 五
JavaScript 初探 七 JavaScript 数据类型 基本的值类型 字符串(String) 数 字(Number) 布尔值(Boolean) 对 象(Object) 函 数(Function ...
- JavaScript初探 三 (学习js数组)
JavaScript初探 (三) JavaScript数组 定义 创建数组 var 数组名 = [元素0,元素1,元素2,--] ; var arr = ["Huawei",&qu ...
随机推荐
- phpcms标签用法(转)
1.显示指定catid的栏目名称和链接 {$CATEGORYS[25]['catname']} {$CATEGORYS[25]['url']} 获取父栏目id/获取父栏目名称 $CATEGORY[ ...
- 2-2 列表推导同 filter 和 map 的比较
列表推导同 filter 和 map 的比较 参考廖雪峰的文档: filter()函数:用于过滤序列. filter()接收一个函数和一个序列.把传入的函数依次作用于传入的序列的每个元素,根据返回值是 ...
- 类似倒圆角方法输入半径选择实体 kword
ads_name ename; ads_point adspt; acedInitGet(NULL, TEXT("R")); while (1) { int rc = acedEn ...
- jquery 实现点评标签 类似淘宝大众点评的 快速准时 货品完好等
111 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <tit ...
- scp 上传文件自动录入密码
--- 服务器IP地址 des_host=serverIp 服务器存储路径(文件上传后存储指定目录下) des_direc=/home/lk/ 服务器用户密码 des_pass=root_passwo ...
- Script:shell脚本生成随机字符串
#!/bin/bash # bash generate random alphanumeric string # # bash generate random character alphanumer ...
- Number 数据类型
//Number 数据类型//包含 整数 小数 NaN(not a number)var a = 1233;var b = 12.34;//1/'a'//把其他数据类型转化成数字,他在转化时,只要字符 ...
- 「 HDU P3336 」 Count the string
题目大意 给出一个长度为 $n$ 的字符串 $s$ 要求你求出 $s$ 的每一个前缀在 $s$ 中出现的次数之和.$n\le 200000$. 解题思路 暴力的对每一个前缀进行一次匹配,求出出现次数后 ...
- selenium下拉滚动条
selenium下拉滚动条 制作人:全心全意 谷歌浏览器下拉滚动条 chrome = webdriver.Chrome() //创建谷歌浏览器对象 url="http://www.baidu ...
- bootstrap中栅格系统的原理
1.基本结构 Bootstrap采取12列的栅格体系,根据主流设备的尺寸进行分段,每段宽度固定,通过百分比和媒体查询实现响应式布局. Bootstrap划分了四种尺寸:超小屏(手机).小屏(平板竖屏) ...