js实现鼠标左右移动,图片也跟着移动效果


Posted in Javascript onJanuary 25, 2017

效果:鼠标往左移,图片对应右移,鼠标往右移,图片就左移动。图片距离越远偏移距离越大。

思路:首先获取图片原先的距离。设置一个变化值,图片的最终距离等于原先的距离加上变化值

布局:大盒子里面是图片,大盒子position:relative;图片position:absolute;

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
<style>
body{margin:0;}
#wrap{width:800px;height:500px;margin:30px auto; border:1px solid #000; position:relative;}
#wrap img{ position:absolute;}
#wrap img:nth-of-type(1){ left:200px;top:200px; z-index:0;}
#wrap img:nth-of-type(2){ left:300px;top:180px; z-index:1;}
#wrap img:nth-of-type(3){ left:100px;top:100px; z-index:2;}
#wrap img:nth-of-type(4){ left:400px;top:110px; z-index:3;}
</style>
</head>
<body>
<div id="wrap">
 <img src="http://cdn.attach.qdfuns.com/notes/pics/201701/18/094455cpacwz1yai2ap43p.jpg.editor.jpg" />
 <img src="http://cdn.attach.qdfuns.com/notes/pics/201701/18/094455csz3xxx1x23um7e9.jpg.editor.jpg" />
 <img src="http://cdn.attach.qdfuns.com/notes/pics/201701/18/094455fv3rzfoov04owrof.jpg.editor.jpg" />
 <img src="http://cdn.attach.qdfuns.com/notes/pics/201701/18/094455fv3rzfoov04owrof.jpg.editor.jpg" />
</div>
<script>
var oWrap=document.getElementById("wrap");
var aImg=oWrap.getElementsByTagName("img");
var iMax=4;
//获取图片的初始位置
for(var i=0;i<aImg.length;i++){
 aImg[i].startX=parseInt(getStyle(aImg[i],'left'))
}
oWrap.onmousemove=function(ev){
 ev=ev||window.event;
 //获取鼠标的位置与大盒子中心点位置的距离
 var iX=ev.clientX-(oWrap.offsetLeft+this.offsetWidth/2)
 for(var i=0;i<aImg.length;i++){
 //获取每个img的z-index
 var iZindex=getStyle(aImg[i],'zIndex')
 //Zindex越大移动的相对距离越小
 var iDisL=-parseInt(iX/iMax*(iMax-iZindex)/5)
 //图片的距离等于原先的距离加上计算的距离
 aImg[i].style.left=aImg[i].startX+iDisL+'px'
 }
}
function getStyle(obj,attr)
{
 if( obj.currentStyle){
 return obj.currentStyle[attr]; 
 }
 return getComputedStyle(obj)[attr]; 
}
</script>
</body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JavaScript 模拟用户单击事件
Dec 31 Javascript
纯javascript实现自动发送邮件
Oct 21 Javascript
浅析jquery数组删除指定元素的方法:grep()
May 19 Javascript
JS+HTML5手机开发之滚动和惯性缓动实现方法分析
Jun 12 Javascript
详解js中常规日期格式处理、月历渲染和倒计时函数
Dec 28 Javascript
jQuery常用选择器详解
Jul 17 jQuery
解决js ajax同步请求造成浏览器假死的问题
Jan 18 Javascript
讲解vue-router之什么是编程式路由
May 28 Javascript
javascript中UMD规范的代码推演
Aug 29 Javascript
jQuery添加新内容的四个常用方法分析【append,prepend,after,before】
Mar 19 jQuery
微信小程序实现bindtap等事件传参
Apr 08 Javascript
vue-cli中实现响应式布局的方法
Mar 02 Vue.js
JavaScript 网页中实现一个计算当年还剩多少时间的倒数计时程序
Jan 25 #Javascript
js实现文字选中分享功能
Jan 25 #Javascript
利用Js+Css实现折纸动态导航效果实例源码
Jan 25 #Javascript
jquery实现拖动效果(代码分享)
Jan 25 #Javascript
angular forEach方法遍历源码解读
Jan 25 #Javascript
three.js实现围绕某物体旋转
Jan 25 #Javascript
基于Marquee.js插件实现的跑马灯效果示例
Jan 25 #Javascript
You might like
帅气的琦玉老师
2020/03/02 日漫
php 正确解码javascript中通过escape编码后的字符
2010/01/28 PHP
PHP中register_globals参数为OFF和ON的区别(register_globals 使用详解)
2012/02/05 PHP
解决nginx不支持thinkphp中pathinfo的问题
2015/07/21 PHP
PHP中快速生成随机密码的几种方式
2017/04/17 PHP
PHP开发之归档格式phar文件概念与用法详解【创建,使用,解包还原提取】
2017/11/17 PHP
图片img的src不变让浏览器重新加载实现方法
2013/03/29 Javascript
jQuery基本过滤选择器使用介绍
2013/04/18 Javascript
20行代码实现的一个CSS覆盖率测试脚本
2013/07/07 Javascript
利用JS判断用户是否上网(连接网络)
2013/12/23 Javascript
JavaScript设计模式之工厂方法模式介绍
2014/12/28 Javascript
浅谈javascript中this在事件中的应用
2015/02/15 Javascript
轻松实现jquery手风琴效果
2016/01/14 Javascript
详解JavaScript的AngularJS框架中的表达式与指令
2016/03/05 Javascript
BootStrap实用代码片段之一
2016/03/22 Javascript
Angularjs使用directive自定义指令实现attribute继承的方法详解
2016/08/05 Javascript
Bootstrap 3 按钮标签实例代码
2017/02/21 Javascript
浅析Visual Studio Code断点调试Vue
2018/02/27 Javascript
Vue项目全局配置微信分享思路详解
2018/05/04 Javascript
Nuxt页面级缓存的实现
2020/03/09 Javascript
[04:09]2014DOTA2国际邀请赛Ti西雅图 历届冠军相继出局 BBC综述今日比赛
2014/07/20 DOTA
[52:03]DOTA2-DPC中国联赛 正赛 Ehome vs iG BO3 第三场 1月31日
2021/03/11 DOTA
Python中的迭代器漫谈
2015/02/03 Python
Python实现统计给定字符串中重复模式最高子串功能示例
2018/05/16 Python
Python实现分段线性插值
2018/12/17 Python
Python中的异常处理try/except/finally/raise用法分析
2019/02/28 Python
python线性插值解析
2020/07/05 Python
Python 创建TCP服务器的方法
2020/07/28 Python
关于HTML5你必须知道的28个新特性,新技巧以及新技术
2012/05/28 HTML / CSS
太阳镜仓库,售价20美元或更少:Sunglass Warehouse
2016/09/28 全球购物
玩具公司的创业计划书
2013/12/31 职场文书
《桂花雨》教学反思
2014/04/12 职场文书
导游词之江苏溱潼古镇
2019/11/27 职场文书
总结高并发下Nginx性能如何优化
2021/11/01 Servers
游戏《我的世界》澄清Xbox版暂无计划加入光追
2022/04/03 其他游戏
Python几种酷炫的进度条的方式
2022/04/11 Python