Javascript实现鼠标移入方向感知
网络编程 2021-07-04 15:03www.168986.cn编程入门
这篇文章主要为大家详细介绍了Javascript实现鼠标移入方向感知,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文介绍了JavaScript检测鼠标移动方向的方法,涉及javascript鼠标操作的相关技巧,供大家参考,具体内容如下
判断鼠标移入方向的功能函数
function getDir(ev, ele) { var l = ele.getBoundingClientRect().left; var t = ele.getBoundingClientRect().; var w = ele.getBoundingClientRect().width; var h = ele.getBoundingClientRect().height; var x = (ev.clientX - l - w / 2) (w > h ? (h / w) : 1); var y = (ev.clientY - t - h / 2) (h > w ? (w / h) : 1); var deg = Math.atan2(y, x) / (Math.PI / 180); var d = (Math.round((deg + 180) / 90) + 3) % 4; return d; // d的值{上:0,右:1,下:2,左:3} }
整体代码
html:
<div id="container"> <img src="./bg.jpg" alt=""> <p class="ps">故事成功地将原本隐藏在黑暗中,用世界上最强大的毅力和最艰辛的努力去做最密不可宣和隐讳残酷的事情的忍者,描绘成了太阳下最值得骄傲最光明无限的职业。在岸本齐史笔下的忍者世界中,每一位年轻的忍者都在开拓着属于自己的忍道。 </p> </div>
CSS:
{ margin: 0; padding: 0; } #container{ width: 400px; height: 200px; position: relative; margin-: 100px; margin-left: 200px; overflow: hidden; } #container img{ width: 100%; height: 100%; transition: 0.5s; } #container p{ width: 100%; height: 100%; padding: 10px; box-sizing: border-box; position: absolute; left: 0; / : 0; / background: rgba(0, 0, 0, .7); color: #c; font-size: 14px; line-height: 24px; } #container:hover img{ transform: scale(1.1); }
JS:
window.onload = function () { var box = document.getElementById('container'); var ps = document.getElementsByClassName('ps'); var pos=[ {left:0,:'-100%'}, {left:'100%',:0}, {left:0,:'100%'}, {left:'-100%',:0} ] box.onmouseenter = function(ev){ var dir = getDir(ev,this); ps[0].style.transition=''; ps[0].style.left=pos[dir].left; ps[0].style.=pos[dir].; setTimeout(function(){ ps[0].style.transition='.3s'; ps[0].style.left=0; ps[0].style.=0; },1000/60) } box.onmouseleave = function(ev){ var dir = getDir(ev,this); setTimeout(function(){ ps[0].style.transition=''; ps[0].style.left=pos[dir].left; ps[0].style.=pos[dir].; },100) } } function getDir(ev, ele) { var l = ele.getBoundingClientRect().left; var t = ele.getBoundingClientRect().; var w = ele.getBoundingClientRect().width; var h = ele.getBoundingClientRect().height; var x = (ev.clientX - l - w / 2) (w > h ? (h / w) : 1); var y = (ev.clientY - t - h / 2) (h > w ? (w / h) : 1); var deg = Math.atan2(y, x) / (Math.PI / 180); var d = (Math.round((deg + 180) / 90) + 3) % 4; return d; // d的值{上:0,右:1,下:2,左:3} }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南