参考 Element 官网,利用 js / jq 和 css3, 实现某图片随着鼠标移动呈现的视差效果。


<!DOCTYPE html>
<html> <head>
<title>banner 跟随鼠标呈现视差效果</title>
<meta charset="utf-8" />
<style>
* {
transition: all .3s;
} .perspective {
perspective: 800px;
} .preserve3d {
position: relative;
width: 500px;
height: 400px;
margin: 160px auto;
background: #4b5cce url("http://data.banyanbbt.org/static/newimg/top/right.png") center no-repeat;
background-size: 100% 100%;
border-radius: 20px;
transform-style: preserve-3d;
}
</style>
</head> <body>
<div class="perspective">
<div class="preserve3d">
</div>
</div> <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.js"></script>
<script type="text/javascript"> /* 原生js实现 */ (function () {
var imgPX = 0;
var imgPY = 0;
var divWidth = 0;
var divHeight = 0;
var flag = false; // 记录鼠标是否按下 var preserve3d = document.querySelector(".preserve3d"); console.log(preserve3d.offsetLeft, preserve3d.offsetTop)
console.log(preserve3d.clientWidth, preserve3d.clientHeight) preserve3d.addEventListener("mouseenter", function (e) {
flag = true;
var evt = e || window.event;
imgPX = preserve3d.offsetLeft;
imgPY = preserve3d.offsetTop;
divWidth = preserve3d.clientWidth;
divHeight = preserve3d.clientHeight; document.addEventListener("mousemove", function (e) {
if (flag) {
var evt = e || window.event;
var mouseX = evt.clientX - imgPX;
var mouseY = evt.clientY - imgPY;
var X = mouseX - divWidth / 2;
var Y = divHeight / 2 - mouseY;
preserve3d.style.transform =
`rotateY(${ X / 20 }deg) rotateX(${ Y / 20 }deg)`
}
}); document.addEventListener("mouseout", function () {
flag = false;
preserve3d.style.transform = `rotateY(${ 0 }deg) rotateX(${ 0 }deg)`
document.removeEventListener("mouseout", function () {
flag = false;
});
}) });
})(); /* jq 实现 */ // (function () {
// var imgPX = 0;
// var imgPY = 0;
// var divWidth = 0;
// var divHeight = 0; // $('.preserve3d').on('mouseenter', function () {
// imgPX = $(this).offset().left;
// imgPY = $(this).offset().top;
// divWidth = $(this).outerWidth();
// divHeight = $(this).outerHeight(); // console.log($(this).offset().left, $(this).offset().top) // }).on('mousemove', function (event) {
// var mouseX = event.pageX - imgPX;
// var mouseY = event.pageY - imgPY;
// var X = mouseX - divWidth / 2;
// var Y = divHeight / 2 - mouseY;
// $(this).css({
// "transform": "rotateY(" + X / 20 + "deg) " + "rotateX(" + Y / 20 + "deg) "
// });
// }).on('mouseleave', function () {
// $(this).css({
// "transform": "rotateY(0deg) rotateX(0deg)"
// })
// })
// })();
</script>
</body> </html>

最新文章

  1. ★Kali信息收集~★6.Dmitry:汇总收集
  2. 允许Sublime编辑器在Ubuntu上输入中文
  3. [SPI&amp;I2C]I2C和SPI协议介绍
  4. VC亲自教你写BP
  5. linux下对date和timestamp的互转
  6. 象写程序一样写博客:搭建基于github的博客
  7. install zabbix-agent on CENTOS
  8. 关于&lt;html&gt;标签里的class= no-js
  9. 1.4.2 solr字段类型--(1.4.2.5)使用枚举字段
  10. debian下软件包管理方式总结
  11. Delphi实现WebService带身份认证的数据传输
  12. C# 标签打印示例 1
  13. 数学之欧拉函数 &amp;几道poj欧拉题
  14. Android开发,Eclipse创建aidl接口时,出错
  15. SVN错误:Attempted to lock an already-locked dir的解决
  16. vue路由--网站导航功能
  17. Java桥接模式
  18. HNOI2019 JOJO
  19. Js中带有小数的值相加产生的问题
  20. 源码版本管理工具 :TFS GIT

热门文章

  1. SQLTest系列之INSERT语句测试
  2. Use Jupyter notebook on Fedora 28
  3. 将 SecondaryNameNode 配置到 s105 节点上
  4. Bank项目
  5. Python glob.md
  6. ftp传输文件到指定服务器
  7. 2017-2018-2 20165318 实验三《Java面向对象程序设计》实验报告
  8. 使用docker搭建hadoop环境,并配置伪分布式模式
  9. laravel记录笔记Laravel 连接数据库、操作数据库的三种方式
  10. Ant在MyEclipse中的配置总结