JS延时提示框实现方法详解
作者:bea
本文实例讲述了JS延时提示框实现方法。分享给大家供大家参考,具体如下: 提示框功能:当鼠标指向头像时,弹出一个信息框,鼠标可移动到信息框,当鼠标离开头像时信息框消失,当鼠标离开信息框时信息框消失。 实现功能思路: 1、获取元素。 2、当鼠标指向Div1时,Div2显示。 3、当鼠标离开Div1时,使Div2延迟0.5秒消失,这样以便有时间把鼠标移到Div2。 4、当鼠标指向Div2时,Div2显示。因为第3步设置setTimeout使Div2消失,所以把用clearTimeo
本文实例讲述了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代码:
<script>
window.onload=function()
{
var oDiv1=document.getElementById('div1');
var oDiv2=document.getElementById('div2');
time=null;
oDiv1.onmouseover=function()
{
clearTimeout(time);
oDiv2.style.display='block';
};
oDiv1.onmouseout=function()
{
time=setTimeout(function(){
oDiv2.style.display='none';
},500);
};
oDiv2.onmouseover=function()
{
clearTimeout(time);
};
oDiv2.onmouseout=function()
{
time=setTimeout(function(){
oDiv2.style.display='none';
},500);
};
};
</script>
由于代码看起来多差不多,可以简化如下:
<script>
window.onload=function()
{
var oDiv1=document.getElementById('div1');
var oDiv2=document.getElementById('div2');
time=null;
oDiv2.onmouseover=oDiv1.onmouseover=function()
{
clearTimeout(time);
oDiv2.style.display='block';
};
oDiv2.onmouseout=oDiv1.onmouseout=function()
{
time=setTimeout(function(){
oDiv2.style.display='none';
},500);
};
};
</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>
希望本文所述对大家JavaScript程序设计有所帮助。
有用 | 无用
提示框功能:当鼠标指向头像时,弹出一个信息框,鼠标可移动到信息框,当鼠标离开头像时信息框消失,当鼠标离开信息框时信息框消失。
实现功能思路:
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代码:
<script>
window.onload=function()
{
var oDiv1=document.getElementById('div1');
var oDiv2=document.getElementById('div2');
time=null;
oDiv1.onmouseover=function()
{
clearTimeout(time);
oDiv2.style.display='block';
};
oDiv1.onmouseout=function()
{
time=setTimeout(function(){
oDiv2.style.display='none';
},500);
};
oDiv2.onmouseover=function()
{
clearTimeout(time);
};
oDiv2.onmouseout=function()
{
time=setTimeout(function(){
oDiv2.style.display='none';
},500);
};
};
</script>
由于代码看起来多差不多,可以简化如下:
<script>
window.onload=function()
{
var oDiv1=document.getElementById('div1');
var oDiv2=document.getElementById('div2');
time=null;
oDiv2.onmouseover=oDiv1.onmouseover=function()
{
clearTimeout(time);
oDiv2.style.display='block';
};
oDiv2.onmouseout=oDiv1.onmouseout=function()
{
time=setTimeout(function(){
oDiv2.style.display='none';
},500);
};
};
</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>
希望本文所述对大家JavaScript程序设计有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 谈谈javascript中使用连等赋值操作带来的问题
- jQuery实现的AJAX简单弹出层效果代码
- js检测iframe是否加载完成的方法
- 学习JavaScript设计模式(策略模式)
- 深入浅析同源策略和跨域访问
- js实现iframe框架取值的方法(兼容IE,firefox,chrome等)
- 学习JavaScript设计模式(单例模式)
- javascript bom是什么及bom和dom的区别
- Javascript模仿淘宝信用评价实例(附源码)
- Javascript BOM学习小结(六)
- js实现延时加载Flash的方法
- 学习JavaScript设计模式(链式调用)
- 学习JavaScript设计模式(继承)
- js图片跟随鼠标移动代码
- 学习JavaScript设计模式(封装)
- JS实现密码框根据焦点的获取与失去控制文字的消失与显示效果
- 学习JavaScript设计模式(接口)
- Jquery中request和request.form和request.querystring的区别
- Jquery检验手机号是否符合规则并根据手机号检测结果将提交按钮设为不同状态