文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

jquery 弹出后自动关闭

2023-05-23 11:40

关注

在网页中,jquery是一个广泛使用的javascript库,可以方便地实现各种交互和动画效果。其中,弹出框是比较常见的一种交互方式,可以引导用户进行操作或提示用户相关信息。一般情况下,弹出框都需要手动关闭,但是在某些场景下,我们需要实现自动关闭的效果,本文将介绍如何使用jquery实现弹出框的自动关闭功能。

一、弹出框的基本实现

在jquery中,我们可以使用弹出框插件或者自己编写代码实现弹出框的效果。这里以自己编写代码的方式为例,简单实现一个弹出框的效果。

HTML代码

<button id="btn">点击弹出框</button>

<div class="mask">
  <div class="popup">
    <h3>弹出框标题</h3>
    <p>弹出框内容</p>
    <button class="close-btn">关闭</button>
  </div>
</div>

CSS代码

.mask {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6)
}

.popup {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 300px;
  padding: 20px;
  background-color: #ffffff;
  border-radius: 5px;
  text-align: center;
}

.close-btn {
  margin-top: 20px;
  padding: 5px 10px;
  border: none;
  background-color: #ff6700;
  color: #ffffff;
  border-radius: 5px;
  cursor: pointer;
}

JS代码

$(function() {
  $('#btn').click(function() {
    $('.mask').fadeIn(500);
  });
  
  $('.close-btn').click(function() {
    $('.mask').fadeOut(500);
  });
})

通过以上代码,我们可以实现一个简单的弹出框效果。点击按钮,页面出现黑色半透明背景并弹出一个白色框体,点击关闭按钮,弹出框消失。接下来,我们将介绍如何实现弹出框的自动关闭功能。

二、使用setTimeout实现自动关闭

在jquery中,有一个setTimeout的方法,可以使代码在指定的时间后自动执行。利用这个方法,我们可以实现弹出框自动关闭的功能。

HTML代码(与上面的代码相同)

CSS代码(与上面的代码相同)

JS代码

$(function() {
  $('#btn').click(function() {
    $('.mask').fadeIn(500);

    // 代码开始执行后,1.5秒后执行自动关闭
    setTimeout(function() {
      $('.mask').fadeOut(500);
    }, 1500);
  });
  
  $('.close-btn').click(function() {
    $('.mask').fadeOut(500);
  });
})

在以上代码中,我们在弹出框显示后(mask元素fadeIn),设置定时器,将自动关闭的代码放入定时器中,其中1500表示1.5秒后执行自动关闭的代码(mask元素fadeOut)。当然,我们也可以将时间设置得更长或更短,来满足不同的需求。

三、使用animation动画实现自动关闭

除了使用setTimeout方法实现自动关闭外,我们还可以使用jquery的动画效果来实现类似的效果。我们可以利用jquery的animate方法将弹出框渐渐消失,从而实现类似于自动关闭的效果。

HTML代码(与上面的代码相同)

CSS代码(与上面的代码相同)

JS代码

$(function() {
  $('#btn').click(function() {
    $('.mask').fadeIn(500);

    // 延迟1.5秒后开始执行动画
    setTimeout(function() {
      $('.popup').animate({opacity: 0});
      $('.mask').animate({opacity: 0}, function() {
        $(this).hide();
      })
    }, 1500);
  });
  
  $('.close-btn').click(function() {
    $('.mask').fadeOut(500);
  });
})

在以上代码中,我们同样设置了定时器,在1.5秒后弹出框开始消失。这里的消失不是直接使用fadeOut方法,而是使用animate方法将opacity(透明度)属性从1渐渐变成0。当透明度变为0时,调用回调函数,将mask元素隐藏。这样就完成了类似于自动关闭的效果。

总结

本文介绍了如何使用jquery实现弹出框的自动关闭功能。我们可以利用setTimeout方法或者animate方法实现自动关闭的效果。希望本文对大家有所帮助。

以上就是jquery 弹出后自动关闭的详细内容,更多请关注编程网其它相关文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯