javascript - 检测鼠标位置并触发功能

标签 javascript html

这个想法是跟踪鼠标的 x 坐标,因此当它进入某个阈值(250px)(在本例中)到窗口的左边缘时,它会触发函数“openNav”,并在鼠标移动时关闭它离开 250px 阈值。

我读了一些论坛和帖子,但似乎找不到太多关于如何使用 ClientX 函数的信息。下面的代码正是我认为它应该如何工作的,但显然不是。如果有人能给我一些关于如何执行上述内容的想法甚至示例,我会很高兴。

提前谢谢您。

function openNav() {
  document.getElementById("mySidenav").style.width = "250px";
  document.getElementById("main").style.marginLeft = "250px";
}

function closeNav() {
  document.getElementById("mySidenav").style.width = "0";
  document.getElementById("main").style.marginLeft = "0";
}

var x = e.clientX;
for (x - 250 <= 0) {
  openNav()
}
body {
  font-family: "Lato", sans-serif;
}

.sidenav {
  height: 100%;
  width: 0;
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  background-color: #111;
  overflow-x: hidden;
  transition: 0.5s;
  padding-top: 60px;
}

.sidenav a {
  padding: 8px 8px 8px 32px;
  text-decoration: none;
  font-size: 25px;
  color: #818181;
  display: block;
  transition: 0.3s;
}

.sidenav a:hover {
  color: #f1f1f1;
}

.sidenav .closebtn {
  position: absolute;
  top: 0;
  right: 25px;
  font-size: 36px;
  margin-left: 50px;
}

#main {
  transition: margin-left .5s;
  padding: 16px;
}

@media screen and (max-height: 450px) {
  .sidenav {
    padding-top: 15px;
  }
  .sidenav a {
    font-size: 18px;
  }
}
<div id="mySidenav" class="sidenav">
  <a href="javascript:void(0)" class="closebtn" onclick="closeNav()">&times;</a>
  <a href="#">1</a>
  <a href="#">2</a>
  <a href="#">3</a>
  <a href="#">4</a>
</div>

<div>
  <button class="button open" onclick="openNav()">OPEN</button>
</div>
<div id="main">
  <h2>Courses</h2>
</div>

最佳答案

只需设置一个具有正确大小和位置的 div,然后在鼠标输入事件上调用您的函数

$('#myDiv').on("mouseenter", function (e) {
  //your code
});

关于javascript - 检测鼠标位置并触发功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49879257/

相关文章:

javascript - 试图获取 Javascript 中所有 TR 行的列表

javascript - 如何调试 JQuery 选项卡的浏览器兼容性问题?

javascript - 预编译的 javascript 文件在 heroku 部署后不起作用,有没有好的 js 文件顺序?

javascript - 如何从 Ajax 调用将非 url 请求参数传递给 Smalltalk Teapot

html - 如何在 Shiny 的应用程序中垂直居中操作按钮?

html - 如何使用 Rails Nokogiri gem 提取 HTML 中的数据属性?

javascript - JS 调整 div 大小

javascript - 如何将百分比分配给 CSSStyleDeclaration 的属性

javascript - FLOT 中的主要和次要刻度线

javascript - 选择后重定向按钮