js实现开屏弹窗

各位上次教大家制作另一个简单的开屏弹窗,但是其中是有一点问题的。比如在刷新页面的时候开屏弹窗会再次出现,但是在现实情况中很少出现这种情况。那我们怎么做呢,这时候就需要用到我们之前学到的BOM中的临时存储了。直接展示好吧。

HTML

html 复制代码
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="styles.css">
    <title>点击消失的开屏弹窗</title>
</head>
<body>

    <div class="splash-screen" id="splashScreen">
        <h1>欢迎来到我的网站</h1>
        <p>点击任意地方关闭此窗口</p>
    </div>

    <div class="content">
        <h2>主内容区域</h2>
        <p>这里是网站的主要内容。</p>
    </div>

    <script src="script.js"></script>
</body>
</html>

CSS (styles.css)

html 复制代码
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: Arial, sans-serif;
}

.splash-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    color: white;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 9999; /* 确保在最上层 */
    transition: opacity 0.5s ease; /* 添加渐变效果 */
}

.content {
    padding: 20px;
}

JavaScript (script.js)

javascript 复制代码
// 获取弹窗元素
let splash = document.getElementById('splashScreen');

// 检查 sessionStorage 中是否已设置弹窗的显示状态
if (sessionStorage.getItem('splashScreenClosed') == '1') {
    splash.style.display = 'none'; // 如果已关闭,隐藏弹窗
} else {
    splash.style.display = 'flex'; // 否则显示弹窗
}

// 处理弹窗的点击事件
splash.addEventListener('click', function() {
    sessionStorage.setItem('splashScreenClosed', '1'); // 设置标志,表示弹窗已关闭
    splash.style.opacity = '0'; // 渐变消失
    setTimeout(() => {
        splash.style.display = 'none'; // 完全隐藏
    }, 500); // 与 CSS 中的过渡时间相同
});

ok了也是非常之简单,接下来带大家整理下整体思路

  1. HTML:

    • 创建了一个带有欢迎消息的弹窗和一个主内容区域。
  2. CSS:

    • 设置 .splash-screen 的样式,使其全屏覆盖并居中显示内容。
  3. JavaScript:

    • 使用 document.getElementById 获取弹窗元素。
    • 在页面加载时检查 sessionStorage 中的 splashScreenClosed 项:
      • 如果值为 '1',则隐藏弹窗。
      • 如果值不存在或不等于 '1',则显示弹窗。
    • 添加一个点击事件监听器,当用户点击弹窗时:
      • splashScreenClosed 设置为 '1',表示弹窗已关闭。
      • 通过设置透明度并使用 setTimeout 来实现平滑的消失效果。
相关推荐
_OP_CHEN2 分钟前
【Python基础】(三)Python 语法基础进阶:条件循环 + 实战案例,从入门到精通的核心跳板
开发语言·python·python入门·条件语句·循环语句·python基础语法
苹果电脑的鑫鑫2 分钟前
.eslintrc.js这个文件作用
开发语言·javascript·ecmascript
ytttr8733 分钟前
matlab进行利用遗传算法对天线阵列进行优化
开发语言·算法·matlab
无限进步_4 分钟前
【C语言】队列(Queue)数据结构的实现与分析
c语言·开发语言·数据结构·c++·算法·链表·visual studio
特立独行的猫a7 分钟前
Google C++ 编码规范核心要点总结 (2025精简版)
开发语言·c++·编码规范
vx_bisheyuange10 分钟前
基于SpringBoot的便利店信息管理系统
前端·javascript·vue.js·毕业设计
晚烛11 分钟前
智启工厂脉搏:基于 OpenHarmony + Flutter 的信创工业边缘智能平台构建实践
前端·javascript·flutter
Zsnoin能14 分钟前
都快2026了,还有人不会国际化和暗黑主题适配吗,一篇文章彻底解决
前端·javascript
两个西柚呀15 分钟前
es6和commonjs模块化规范的深入理解
前端·javascript·es6
快乐非自愿15 分钟前
Java函数式接口——渐进式学习
java·开发语言·学习