JavaScript实现跟随鼠标移动的盒子


Posted in Javascript onJanuary 28, 2021

本文实例为大家分享了JavaScript实现跟随鼠标移动的具体代码,供大家参考,具体内容如下

跟随鼠标移动的盒子(包括检测边界值)

效果图:

JavaScript实现跟随鼠标移动的盒子

代码:

<!DOCTYPE html>
<html lang="en">
 
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>
  div {
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100px;
    height: 100px;
    background-color: red;
  }
</style>
 
<body>
  <div>111111111</div>
  <script>
    var div = document.getElementsByTagName('div')[0];
    div.onmousedown = function(e) {
      e = window.event || e;
      // 鼠标按下 获取鼠标距离页面左侧距离
      var x = e.clientX;
      // 获取鼠标距离页面上侧距离
      var y = e.clientY;
      // 元素距离页面左侧距离
      var elex = div.offsetLeft;
      // 元素距离页面上侧距离
      var eley = div.offsetTop;
      // 相减得到鼠标距离元素的距离
      var X = x - elex;
      var Y = y - eley;
      console.log(X, Y);
      document.onmousemove = function(e) {
          e = window.event || e;
          // 鼠标移动过程中 获取鼠标距离页面距离
          var movex = e.clientX;
          var movey = e.clientY;
          // 1.左侧边界值
          // 元素移动过程中距离页面左侧距离
          var leftx = movex - X;
          var lefty = movey - Y;
          // 1.左侧边界值
          if (leftx <= 0) {
            leftx = 0;
          }
          // 2.上侧边界值
          if (lefty <= 0) {
            lefty = 0
          }
          // 3.右侧边界值
          // 页面可视区宽 -元素宽
          var rightx = document.documentElement.clientWidth - div.offsetWidth;
          if (leftx >= rightx) {
            leftx = rightx
          }
          // 4.下侧边界值
          // 页面可视区高 -元素高
          var righty = document.documentElement.clientHeight - div.offsetHeight;
          if (lefty >= righty) {
            lefty = righty;
          }
          // 鼠标移动过程中 获取鼠标距离页面距离 - 鼠标距离元素的距离 =元素的left top值
          div.style.left = leftx + 'px';
          div.style.top = lefty + 'px';
 
 
 
        }
        // 抬起清除移动事件
      document.onmouseup = function() {
          document.onmousemove = null;
        }
        // 阻止默认事件
      return false;
 
    }
  </script>
</body>
 
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
手把手教你自己写一个js表单验证框架的方法
Sep 14 Javascript
JavaScript中Math.SQRT2属性的使用详解
Jun 14 Javascript
jquery正则表达式验证(手机号、身份证号、中文名称)
Dec 31 Javascript
Angularjs中如何使用filterFilter函数过滤
Feb 06 Javascript
JavaScript正则表达式的分组匹配详解
Feb 13 Javascript
JavaScript中误用/g导致的正则test()无法正确重复执行的解决方案
Jul 27 Javascript
JS 实现 ajax 异步浏览器兼容问题
Jan 21 Javascript
纯JS实现轮播图
Feb 22 Javascript
react-native DatePicker日期选择组件的实现代码
Sep 12 Javascript
bootstrap paginator分页插件的两种使用方式实例详解
Nov 14 Javascript
three.js 如何制作魔方
Jul 31 Javascript
vue 监听 Treeselect 选择项的改变操作
Aug 31 Javascript
vue.js实现点击图标放大离开时缩小的代码
Jan 27 #Vue.js
使用JS实现鼠标放上图片进行放大离开实现缩小功能
Jan 27 #Javascript
vscode自定义vue模板的实现
Jan 27 #Vue.js
vue+echarts实现中国地图流动效果(步骤详解)
Jan 27 #Vue.js
js实现鼠标切换图片(无定时器)
Jan 27 #Javascript
JavaScript实现切换多张图片
Jan 27 #Javascript
jquery实现点击左右按钮切换图片
Jan 27 #jQuery
You might like
受疫情影响 动画《Re从零开始的异世界生活》第二季延期至7月
2020/03/10 日漫
PHP安全配置
2006/10/09 PHP
Mysql的Root密码忘记,查看或修改的解决方法(图文介绍)
2013/06/14 PHP
PHP中的reflection反射机制测试例子
2014/08/05 PHP
javascript自定义的addClass()方法
2014/05/28 Javascript
node.js中的url.resolve方法使用说明
2014/12/10 Javascript
Angular用来控制元素的展示与否的原生指令介绍
2015/01/07 Javascript
JavaScript资源预加载组件和滑屏组件的使用推荐
2016/03/10 Javascript
客户端验证用户名和密码的方法详解
2016/06/16 Javascript
浅谈箭头函数写法在ReactJs中的使用
2017/08/22 Javascript
Bootstrap一款超好用的前端框架
2017/09/25 Javascript
VUE接入腾讯验证码功能(滑块验证)备忘
2019/05/07 Javascript
在vue中axios设置timeout超时的操作
2020/09/04 Javascript
ant design vue嵌套表格及表格内部编辑的用法说明
2020/10/28 Javascript
JS实现鼠标移动拖尾
2020/12/27 Javascript
[15:57]教你分分钟做大人:斧王
2014/10/30 DOTA
python 多线程中子线程和主线程相互通信方法
2018/11/09 Python
numpy linalg模块的具体使用方法
2019/05/26 Python
通过cmd进入python的实例操作
2019/06/26 Python
Python imread、newaxis用法详解
2019/11/04 Python
python定间隔取点(np.linspace)的实现
2019/11/27 Python
Python matplotlib实时画图案例
2020/04/23 Python
python 实现Harris角点检测算法
2020/12/11 Python
python读取图片颜色值并生成excel像素画的方法实例
2021/02/19 Python
印度领先的在线时尚商店:Koovs
2016/08/28 全球购物
新秀丽官方旗舰店:Samsonite拉杆箱、双肩包、皮具
2018/03/05 全球购物
Vector, ArrayList, HashTable, HashMap哪些是线程安全的,哪些不是
2015/10/12 面试题
施工安全协议书
2013/12/11 职场文书
新闻学专业大学生职业生涯规划范文
2014/03/02 职场文书
银行办公室岗位职责
2014/03/10 职场文书
幼儿园小班家长寄语
2014/04/02 职场文书
大学学生会主席竞选稿
2015/11/19 职场文书
团支部组织委员竞选稿
2015/11/21 职场文书
MongoDB balancer的使用详解
2021/04/30 MongoDB
用Python爬虫破解滑动验证码的案例解析
2021/05/06 Python
浅析Python OpenCV三种滤镜效果
2022/04/11 Python