☀【组件 - 工具】Parallax 视差
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<style>
body{overflow:hidden;}
#box1{position:absolute;top:100px;left:670px;width:100px;height:20px;background:red;}
#box2{position:absolute;top:120px;left:670px;width:100px;height:20px;background:blue;}
#box3{position:absolute;top:0;left:50%;width:1px;height:600px;background:red;}
#box4{position:absolute;top:0;left:37.5%;width:1px;height:600px;background:red;}
#tip{position:absolute;background:green;color:white;}
</style>
<div id="box1"></div>
<div id="box2"></div>
<div id="box3"></div>
<div id="box4"></div>
<div id="box5"></div>
<div id="tip"><span id="tip-horz"></span>|<span id="tip-vert"></span></div>
<script>
var throttle = function(fn, delay, immediate, debounce) {
var curr = +new Date(),
last_call = 0,
last_exec = 0,
timer = null,
diff,
context,
args,
exec = function() {
last_exec = curr;
fn.apply(context, args);
};
return function() {
curr = +new Date();
context = this;
args = arguments;
diff = curr - (debounce ? last_call : last_exec) - delay;
clearTimeout(timer); if (debounce) {
if (immediate) {
timer = setTimeout(exec, delay);
} else if (diff >= 0) {
exec();
}
} else {
if (diff >= 0) {
exec();
} else if (immediate) {
timer = setTimeout(exec, -diff);
}
} last_call = curr;
}
}; var debounce = function (fn, delay, immediate) {
return throttle(fn, delay, immediate, true);
}; var viewportW = document.documentElement.clientWidth
var initialized = false var oldx, oldy;
document.onmousemove = throttle(function(e) {
var posx = 0,
posy = 0,
e = e || window.event,
get = function(id) {
return document.getElementById(id);
},
box1 = get('box1'),
box2 = get('box2'),
tip = get('tip'),
tipHorz = get('tip-horz'),
tipVert = get('tip-vert'); if (e.pageX || e.pageY) {
posx = e.pageX;
posy = e.pageY;
} else if (e.clientX || e.clientY) {
posx = e.clientX + document.documentElement.scrollLeft + document.body.scrollLeft;
posy = e.clientY + document.documentElement.scrollTop + document.body.scrollTop;
}; tip.style.top = +posy + 15 + 'px';
tip.style.left = +posx + 15 + 'px'; if (oldx == null || oldy == null) {
oldx = posx;
oldy = posy;
return;
} if (posx - oldx == 0) {
tipHorz.innerHTML = '----';
}
if (posx - oldx > 0) {
tipHorz.innerHTML = 'right';
box1.style.left = parseFloat(box1.offsetLeft) + (posx - oldx)/4 + 'px';
box2.style.left = parseFloat(box2.offsetLeft) + (posx - oldx)/4 + 'px';
}
if (posx - oldx < 0) {
tipHorz.innerHTML = 'left';
box1.style.left = parseFloat(box1.offsetLeft) + (posx - oldx)/4 + 'px';
box2.style.left = parseFloat(box2.offsetLeft) + (posx - oldx)/4 + 'px';
}
if (posy - oldy == 0) {
tipVert.innerHTML = '----';
}
if (posy - oldy > 0) {
tipVert.innerHTML = 'bottom';
}
if (posy - oldy < 0) {
tipVert.innerHTML = 'top';
} oldx = posx;
oldy = posy; if (!initialized) {
box1.style.left = viewportW / 2 - 50 - (viewportW / 2 - posx) / 4 + 'px'
initialized = true
}
}, 30, false);
</script>
</body>
</html>
☀【组件 - 工具】Parallax 视差的更多相关文章
- web组件工具之获取表单数据:webUtils
本文需要的架包:commons-beanutils-1.8.3.jar.commons-logging-1.1.3.jar.servlet-api.jar. 本文共分为五部分:1)封装通用工具类:从表 ...
- Visual Studio: 一键卸载所有组件工具,彻底卸载干净。
第一步.手动卸载VS主体 第二步.下载工具并解压 网盘下载地址:https://pan.baidu.com/s/1eSHRYxW 也可以在Github上下载最新版本:https://github.co ...
- 【分享】Vue 资源典藏(UI组件、开发框架、服务端、辅助工具、应用实例、Demo示例)
Vue 资源典藏,包括:UI组件 开发框架 服务端 辅助工具 应用实例 Demo示例 element ★11612 - 饿了么出品的Vue2的web UI工具套件 Vux ★7503 - 基于Vue和 ...
- Vue UI组件 开发框架 服务端 辅助工具 应用实例 Demo示例
Vue UI组件 开发框架 服务端 辅助工具 应用实例 Demo示例 element ★11612 - 饿了么出品的Vue2的web UI工具套件 Vux ★7503 - 基于Vue和WeUI的组件库 ...
- Unity 自动生成组件索引类工具
Unity 自动生成组件索引类工具 需求由来 我们在写UI类时 需要获取预设中的组件 joystick = transform.Find("joystick"); backgrou ...
- Android常用组件
UI相关 图片 Android-Universal-Image-Loader:com.nostra13.universalimageloader:异步加载.缓存.显示图片 ImageLoader:co ...
- Android常用组件【转】
UI相关 图片 Android-Universal-Image-Loader:com.nostra13.universalimageloader:异步加载.缓存.显示图片 ImageLoader:co ...
- Android经常使用开源组件汇总
http://www.cnblogs.com/scige/p/3456790.html UI相关 图片 Android-Universal-Image-Loader:com.nostra13.univ ...
- VUE组件汇总
内容 UI组件 开发框架 实用库 服务端 辅助工具 应用实例 Demo示例 UI组件 element ★13489 - 饿了么出品的Vue2的web UI工具套件 Vux ★8133 - 基于Vue和 ...
随机推荐
- NET/ASP.NET Routing路由(深入解析路由系统架构原理)(转载)
NET/ASP.NET Routing路由(深入解析路由系统架构原理) 阅读目录: 1.开篇介绍 2.ASP.NET Routing 路由对象模型的位置 3.ASP.NET Routing 路由对象模 ...
- HttpWebRequest结合HtmlAgilityPack实现网页form提交
年前一个项目,需要在某个系统实现系统自动操作. 系统页面使用form提交,页面参数较多,也参数设计一系列计算逻辑,改动一个值,其他值自动改变. 传统方法使用正则表达式匹配参数,构建post参数进行请求 ...
- inner join跟where查询的区别
- Spring中 bean定义的parent属性机制的实现分析
在XML中配置bean元素的时候,我们常常要用到parent属性,这个用起来很方便就可以让一个bean获得parent的所有属性 在spring中,这种机制是如何实现的? 对于这种情况 tra ...
- [FTP] FTPHelper-FTP帮助类,常用操作方法 (转载)
点击下载 FTPHelper.zip 这个类是FTP服务器的一些操作1.连接FTP服务器 2.上传3.下载4.删除文件5.获取当前目录下明细(包含文件和文件夹) 6.获取FTP文件列表(包括文件夹) ...
- SQL For Xml
最近遇到点棘手的问题,大致如下: 1.数据局格式: 企业名称 排口名称 监测时间 监测因子 a b c pH值 a b c 氨氮 a b c 化学需氧量(COD) 企业名称.排口名称 ...
- javascript-图片横向无缝隙滚动(可在服务器运行)
前两次弄'图片横向滚动'javascript,在本地上运行得很美,可是一上到我们学校后台的服务器,就有很多问题,这个算是行的了. css代码: <style type="text/cs ...
- Java 中文件下载的几种应用
public HttpServletResponse download(String path, HttpServletResponse response) { try { // path是指欲下载的 ...
- CSS jQuery HTML5 CSS3
jquery css3图片文字介绍鼠标滚动页面动画单页 http://www.17sucai.com/preview/1/2013-12-30/%E5%8A%A8%E7%94%BB%E5%8D%95% ...
- 推送消息实现icon角标的动态显示
在你自己服务器上做计数,客户端做减法并反馈给你的服务器 ,然后你服务器将需要显示的数字发送给苹果推送服务器(就是消息中的badge)比如:1,你服务器上发送出去3个推送消息到A手机 ...