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 来实现平滑的消失效果。
相关推荐
小奋斗2 分钟前
深入浅出:ES5/ES6+数组扁平化详解
javascript·面试
萤丰信息8 分钟前
技术赋能安全:智慧工地构建城市建设新防线
java·大数据·开发语言·人工智能·智慧城市·智慧工地
掘金安东尼11 分钟前
解读 hidden=until-found 属性
前端·javascript·面试
1024小神19 分钟前
jsPDF 不同屏幕尺寸 生成的pdf不一致,怎么解决
前端·javascript
古夕30 分钟前
my-first-ai-web_问题记录02:Next.js 15 动态路由参数处理
前端·javascript·react.js
Pocker_Spades_A31 分钟前
飞算JavaAI家庭记账系统:从收支记录到财务分析的全流程管理方案
java·开发语言
清风不问烟雨z2 小时前
不仅仅是 Mock 服务:mock-h3,让前端也能优雅拥有后端能力
前端·javascript·vite
CHEN5_022 小时前
【Java基础常见辨析】重载与重写,深拷贝与浅拷贝,抽象类与普通类
java·开发语言
Lsx_2 小时前
TypeScript 是怎么去查找类型定义的?
前端·javascript·typescript
Despacito0o2 小时前
C语言基础:变量与进制详解
java·c语言·开发语言