html+css+js气泡弹窗

界面 图片没截好,实际字是很清晰的

点赞加关注,谢谢

源代码

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>Popup Example</title>

<style>

body {

display: flex;

justify-content: center;

align-items: center;

height: 100vh;

margin: 0;

position: relative;

overflow: hidden;

}

.popup-container {

position: absolute;

top: 0;

left: 0;

width: 100%;

height: 100%;

display: flex;

justify-content: center;

align-items: flex-start;

visibility: hidden;

opacity: 0;

transition: visibility 0s 1.5s, opacity 1.5s;

z-index: 1000;

}

.popup-container.visible {

visibility: visible;

opacity: 1;

transition: visibility 0s, opacity 1.5s;

}

.popup {

background: rgba(255, 255, 255, 0.7);

border-radius: 10px;

box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23);

padding: 20px;

width: 300px;

max-height: 0;

overflow: hidden;

margin-top: 20px;

transition: max-height 0.5s ease-in-out, margin-top 0.5s ease-in-out;

}

.popup.open {

max-height: 400px;

margin-top: 0;

}

.popup-overlay {

position: absolute;

top: 0;

left: 0;

width: 100%;

height: 100%;

background: rgba(0, 0, 0, 0.5);

z-index: 999;

display: none;

}

.button {

border: none;

display: inline-block;

background: black;

color: white;

border-radius: 5px;

padding: 10px 20px;

margin-top: 10px;

cursor: pointer;

box-shadow: 0 2px 5px rgba(0, 0, 0, 0.26);

transition: box-shadow 0.3s ease-in-out;

}

.button:active {

box-shadow: none;

}

</style>

</head>

<body>

<button class="button" οnclick="togglePopup()">弹出</button>

<div class="popup-overlay" id="popupOverlay"></div>

<div class="popup-container" id="popupContainer">

<div class="popup" id="popup">

<p>微信安装完成,点击查看</p>

<!-- 注意:这里没有"确认"按钮,因为我们将使用延迟自动关闭 -->

</div>

</div>

<script>

function togglePopup() {

const popupContainer = document.getElementById('popupContainer');

const popup = document.getElementById('popup');

const popupOverlay = document.getElementById('popupOverlay');

// 添加类以显示弹出窗口和遮罩

popupContainer.classList.add('visible');

popup.classList.add('open');

popupOverlay.style.display = 'block';

// 设置1.5秒后自动关闭弹出窗口

setTimeout(() => {

popupContainer.classList.remove('visible');

popup.classList.remove('open');

popupOverlay.style.display = 'none';

}, 1500);

}

// 初始化时自动触发一次弹出窗口(如果需要)

// togglePopup(); // 取消注释以在页面加载时立即显示弹出窗口

</script>

</body>

</html>

相关推荐
十八朵郁金香36 分钟前
【VUE案例练习】前端vue2+element-ui,后端nodo+express实现‘‘文件上传/删除‘‘功能
前端·javascript·vue.js
LCG元1 小时前
Vue.js组件开发-实现全屏图片文字缩放切换特效
前端·javascript·vue.js
还是鼠鼠2 小时前
图书管理系统 Axios 源码__新增图书
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
还是鼠鼠5 小时前
图书管理系统 Axios 源码 __删除图书功能
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
轻口味5 小时前
Vue.js `Suspense` 和异步组件加载
前端·javascript·vue.js
m0_zj7 小时前
8.[前端开发-CSS]Day08-图形-字体-字体图标-元素定位
前端·css
还是鼠鼠7 小时前
图书管理系统 Axios 源码__编辑图书
前端·javascript·vscode·ajax·前端框架
北极象7 小时前
vue3中el-input无法获得焦点的问题
前端·javascript·vue.js
百度网站快速收录7 小时前
网站快速收录:如何优化网站头部与底部信息?
前端·html·百度快速收录·网站快速收录
GISer_Jing8 小时前
react redux监测值的变化
前端·javascript·react.js