一、效果图

二、需求描述

  1、鼠标经过table每一行时,弹出div动态提示语;

  2、div弹出层的位置随鼠标位置的变化而变化;

  3、鼠标离开table或获取的动态提示语为空时,div弹出层消失。

  下面我做了一个简单的实现,第一次在博客园写随笔记录下来。

三、实现思路

  1、设计一个div弹出层的样式。该div在页面只有一个,哪里需要就往哪里搬。

  2、获取并保存鼠标的位置,定位div弹出层的位置。

  3、获取table每行隐藏的提示语,设置到div中区显示。

  4、使用鼠标经过和离开事件,对div进行控制。

四、具体实现步骤

  1、定义div的HTML代码如下:

  <div class="hoverdiv">
    <div style="text-align: center; vertical-align: middle;"><label id="message" style="color: #000000;"></label></div>
  </div>

  //保存鼠标的位置

  <input type="hidden" id="pagex" />

  <input type="hidden" id="pagey" />

  2、div样式 

  <style type="text/css">
    .blockdiv{
      width:285px;
      height:30px;
      display:none;
      left: 977px;
      top: 300px;
      position: absolute;
      z-index:1002;
      opacity:1;
      background:#D6D6D6;
    }
  </style>

  3、需要鼠标经过table每一行,弹出div,table设计如下:

  <table>
    <thead>
      <tr>
        <th class="center">name</th>
        <th>pass</th>
      </tr>
    </thead>
    <tbody>
    #foreach(${item} in ${draftPage.result})
      <tr class="hoverTag">
        <td>
          <label>
            <input type="hidden" name="message" value="$!dateTool.format("yyyy-MM-dd HH:mm:ss", $!{item.tagTime})">

          </label>
        </td>
        <td>$!{item.name}</td>
        <td>$!{item.pass}</td>
      </tr>
    #end
    </tbody
  </table>

  4、鼠标经过和离开事件处理如下:

  <script>
    //获取鼠标的位置,并保存到页面隐藏域中
    $(document).mousemove(function (e) {
      document.getElementById("pagex").value = e.pageX;//pageX() 属性是鼠标指针的位置,相对于文档的左边缘。
      document.getElementById("pagey").value = e.pageY;//pageY() 属性是鼠标指针的位置,相对于文档的上边缘。
    });

    var MouseEvent = function(e){
      this.x = e.pageX;
      this.y = e.pageY;
    }

    var Mouse = function(e){
      var kdheight = jQuery(document).scrollTop();
      mouse = new MouseEvent(e);
      leftpx = mouse.x+15;
      toppx = mouse.y-10;
    }

    $(".hoverTag").hover(
      function (e) {//鼠标经过时业务处理

        Mouse(e);
        var message = e.currentTarget.firstElementChild.firstElementChild.lastElementChild.defaultValue;
        if(message == null || message == '' || message == undefined){
          $(".hoverdiv").css({
            "display": "none",
          });
          $("#message").html("");
        }else{
          $(".hoverdiv").css({
            "display": "block",
            "left": leftpx,
            "top": toppx,
          });
          $("#message").html(message);
        }
      },
      function () {//鼠标离开时业务处理
        $(".hoverdiv").css({
          "display": "none",
        });
        $("#message").html("");
      }
    )
  </script>

Jquery hover鼠标经过时弹出div动态提示语的更多相关文章

  1. 工作当中实际运用(3)——js原生实现鼠标点击弹出div层 在点击隐藏

    function onmou(){ var divs=document.getElementById('kefuDV');//获取到你要操作的div if (divs.style.display==& ...

  2. JavaScript总结之鼠标划过弹出div单击出现对话框

    为了满足他们的永无止境的要求,我可谓是任劳任怨啊,累断了双手,看瞎了双眼.这个是来写鼠标划过一个按钮,然后弹出一个小提示框解释,另外根据radio是否选中,判断点击后如何执行,然后执行之后再有一个确认 ...

  3. JavaScript鼠标事件,点击鼠标右键,弹出div

    document.oncontextmenu = function(){return false}; //禁止鼠标右键菜单显示 var res = document.getElementById('b ...

  4. jQuery实现鼠标移上弹出提示框,移出消失

    <TD>里有一行数据 "那片笑声让我想起......"  假设超出规定长度将用......代替, 而现在要通过鼠标移动到......上 显示全部内容,移出则消失.如下图 ...

  5. Win7关机时弹出对话框,提示你想要的信息

    博主换了个公司,要求每天写日志,次日8点前没写的话就要扣钱,1篇10块钱,博主已经两次写完忘记提交到ERP系统了,捂脸... 因为公司要求所有工作在公司配的台式电脑上,所以如果能在关机前弹个提示(不关 ...

  6. jQuery 弹出div层

    目的:使用jQuery弹出一个div窗口:这种效果经常应用于页面内容的展示,登录效果的实现.其实,实现这种效果有好多种方式: 效果如下: 代码如下: <html> <head> ...

  7. 鼠标滑过弹出jquery在线客服

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. 基于jQuery鼠标点击弹出登陆框效果

    基于jQuery鼠标点击弹出登陆框效果.这是一款扁平样式风格的jQuery弹出层登陆框特效.效果图如下: 在线预览   源码下载 实现的代码. html代码: <input type=" ...

  9. jQuery插件--zTree中点击节点实现页面跳转时弹出两个页面的问题

    这是第一次使用zTree,所以在使用之前我要先写一个demo来学习一下.我们要注意的是,zTree是一个jQuery插件,所以我们在导入zTree的js文件之前要先导入jQuery的js文件. 我们先 ...

随机推荐

  1. 搭建tdh平台

    1.卸载tdh平台(见tdh集群卸载文件夹) 在manager节点执行chmod +x uninstall.sh (非root用户执行sudo chmod +x uninstall.sh)开始卸载TD ...

  2. pbds初探

    今年暑假外校集训的时候一道题标算是最短路扩展,然而std用的是pbds,于是就产生了研究的兴趣.结果那个标程我现在死都找不到了233 定义: 在知乎上看到有oier去年向CCF发了邮件,得到的回复是p ...

  3. Smith Numbers POJ - 1142 暴力递归枚举

    题意: 给你一个数x,把这个分解成素数之积(假设是x1*x2*x3),如果   x的每一数位的和   等于  x1每一数位的和加上x2每一数位的和加上x3每一数位的和,那么他就是题目要找的数 示例: ...

  4. 【Azure 微服务】基于已经存在的虚拟网络(VNET)及子网创建新的Service Fabric并且为所有节点配置自定义DNS服务

    问题描述 创建新的Service Fabric集群,可以通过门户,Powershell命令,或者是ARM模板.但是通过门户和PowerShell命令时,创建的SF集群都会自动新建一个虚拟网络而无法使用 ...

  5. Kubernets二进制安装(14)之flannel之SNAT规则优化

    flannel之SNAT规则优化的目的是由于在K8S中的容器内,访问不同宿主机中的容器的资源的时候,日志文件会记录为宿主机的IP地址,而不是记录为容器本身自己的IP地址,建议在不同的宿主机上的容器互访 ...

  6. 二进制方式安装docker(非root用户启动docker)

    二进制方式安装docker(非root用户启动docker) 一.下载安装包: 地址:https://download.docker.com/linux/static/stable/x86_64/ 这 ...

  7. KafkaConsumer 简析

    使用方式 创建一个 KafkaConsumer 对象订阅主题并开始接收消息: Properties properties = new Properties(); properties.setPrope ...

  8. woj1019 Curriculum Schedule 输入输出 woj1020 Adjacent Difference 排序

    title: woj1019 Curriculum Schedule 输入输出 date: 2020-03-19 10:43:00 categories: acm tags: [acm,woj] 水题 ...

  9. Leetcode(20)-有效的括号

    给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效. 有效字符串需满足: 左括号必须用相同类型的右括号闭合. 左括号必须以正确的顺序闭合. 注意空字符串可被认 ...

  10. P4213 【模板】杜教筛(杜教筛)题解

    题意: 求\(\sum_{i=1}^n\varphi(i)\)和\(\sum_{i=1}^n\mu(i)\) 思路: 由性质可知:\(\mu*I=\epsilon,\varphi*I=id\)那么可得 ...