Rumah  >  Artikel  >  hujung hadapan web  >  javascript提示框实现延迟提示代码详解

javascript提示框实现延迟提示代码详解

伊谢尔伦
伊谢尔伦asal
2017-07-22 10:43:091327semak imbas

提示框功能:当鼠标指向头像时,弹出一个信息框,鼠标可移动到信息框,当鼠标离开头像时信息框消失,当鼠标离开信息框时信息框消失。

实现功能思路:

1、获取元素。
2、当鼠标指向p1时,p2显示。
3、当鼠标离开p1时,使p2延迟0.5秒消失,这样以便有时间把鼠标移到p2。
4、当鼠标指向p2时,p2显示。因为第3步设置setTimeout使p2消失,所以把用clearTimeout()把setTimeout清除了就可以实现p2显示了。
5、当鼠标离开p2时,使p2延迟0.5秒消失,这样以便有时间把鼠标指向p1。
6、第2步已经设置了鼠标指向p1,p2就显示,但由于第5步设置setTimeout使p2消失,所以在第2步加上clearTimeout()把setTimeout清除了就可以实现p2显示了。

JS代码


<script>
window.onload=function()
{
  var op1=document.getElementById(&#39;p1&#39;);
  var op2=document.getElementById(&#39;p2&#39;);
  time=null;
  op1.onmouseover=function()
  {
    clearTimeout(time);
    op2.style.display=&#39;block&#39;;  
  };
  op1.onmouseout=function()
  {
    time=setTimeout(function(){
      op2.style.display=&#39;none&#39;;
    },500);
  };
  op2.onmouseover=function()
  {
    clearTimeout(time);
  };
  op2.onmouseout=function()
  {
    time=setTimeout(function(){
      op2.style.display=&#39;none&#39;;
    },500);
  };
};
</script>

由于代码看起来多差不多,可以简化如下:


<script>
window.onload=function()
{
  var op1=document.getElementById(&#39;p1&#39;);
  var op2=document.getElementById(&#39;p2&#39;);
  time=null;
  op2.onmouseover=op1.onmouseover=function()
  {
    clearTimeout(time);
    op2.style.display=&#39;block&#39;;  
  };
  op2.onmouseout=op1.onmouseout=function()
  {
    time=setTimeout(function(){
      op2.style.display=&#39;none&#39;;
    },500);
  };
};
</script>

HTML、CSS代码:


<p id="p1"></p>
<p id="p2"></p>
<style>
#p1{float:left;margin-right:10px;width:50px;height:50px;background:black;}
#p2{display:none;float:left;width:200px;height:200px;background:#0CF;}
</style>

Atas ialah kandungan terperinci javascript提示框实现延迟提示代码详解. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn