• JS延时提示框


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

    实现功能思路

    1、获取元素。

    2、当鼠标指向Div1时,Div2显示。

    3、当鼠标离开Div1时,使Div2延迟0.5秒消失,这样以便有时间把鼠标移到Div2。

    4、当鼠标指向Div2时,Div2显示。因为第3步设置setTimeout使Div2消失,所以把用clearTimeout()把setTimeout清除了就可以实现Div2显示了。

    5、当鼠标离开Div2时,使Div2延迟0.5秒消失,这样以便有时间把鼠标指向Div1。

    6、第2步已经设置了鼠标指向Div1,Div2就显示,但由于第5步设置setTimeout使Div2消失,所以在第2步加上clearTimeout()把setTimeout清除了就可以实现Div2显示了。

    JS代码:

     1 <script>
     2 window.onload=function()
     3 {
     4     var oDiv1=document.getElementById('div1');
     5     var oDiv2=document.getElementById('div2');
     6     time=null;
     7     
     8     oDiv1.onmouseover=function()
     9     {
    10         clearTimeout(time);
    11         oDiv2.style.display='block';    
    12     };
    13     
    14     oDiv1.onmouseout=function()
    15     {
    16         time=setTimeout(function(){
    17             oDiv2.style.display='none';
    18         },500);
    19     };
    20     
    21     oDiv2.onmouseover=function()
    22     {
    23         clearTimeout(time);
    24     };
    25     
    26     oDiv2.onmouseout=function()
    27     {
    28         time=setTimeout(function(){
    29             oDiv2.style.display='none';
    30         },500);
    31     };
    32 };
    33 </script>

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

     1 <script>
     2 window.onload=function()
     3 {
     4     var oDiv1=document.getElementById('div1');
     5     var oDiv2=document.getElementById('div2');
     6     time=null;
     7     
     8     oDiv2.onmouseover=oDiv1.onmouseover=function()
     9     {
    10         clearTimeout(time);
    11         oDiv2.style.display='block';    
    12     };
    13     
    14     oDiv2.onmouseout=oDiv1.onmouseout=function()
    15     {
    16         time=setTimeout(function(){
    17             oDiv2.style.display='none';
    18         },500);
    19     };
    20 };
    21 </script>

    HTML、CSS代码:

    <div id="div1"></div>
    <div id="div2"></div>
    
    
    <style>
    #div1{float:left;margin-right:10px;width:50px;height:50px;background:black;}
    #div2{display:none;float:left;width:200px;height:200px;background:#0CF;}
    </style>
  • 相关阅读:
    iOS:Objective-C中Self和Super详解
    调试工具Instruments----Core Animation
    iOS开发之复制字符串到剪贴板
    Copy 和 mutableCopy
    TCP/IP,Http,Socket,XMPP的区别
    iOS程序中的内存分配 栈区堆区全局区(转)
    iOS常见算法(二分法 冒泡 选择 快排)
    老司机带你走进Core Animation
    C# 爬虫小程序
    C# 房贷计算器
  • 原文地址:https://www.cnblogs.com/52css/p/2938385.html
Copyright © 2020-2023  润新知