打开弹窗 &l…">
当前位置:首页 > JavaScript

js实现页面弹窗

2026-01-30 22:13:53JavaScript

使用原生JavaScript实现弹窗

创建一个基础的HTML结构,包含触发弹窗的按钮和弹窗内容

<button id="openModal">打开弹窗</button>
<div id="myModal" class="modal">
  <div class="modal-content">
    <span class="close">&times;</span>
    <p>这里是弹窗内容</p>
  </div>
</div>

添加CSS样式控制弹窗显示和隐藏

.modal {
  display: none;
  position: fixed;
  z-index: 1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.4);
}

.modal-content {
  background-color: #fefefe;
  margin: 15% auto;
  padding: 20px;
  border: 1px solid #888;
  width: 80%;
}

.close {
  color: #aaa;
  float: right;
  font-size: 28px;
  font-weight: bold;
  cursor: pointer;
}

JavaScript控制弹窗逻辑

const modal = document.getElementById("myModal");
const btn = document.getElementById("openModal");
const span = document.getElementsByClassName("close")[0];

btn.onclick = function() {
  modal.style.display = "block";
}

span.onclick = function() {
  modal.style.display = "none";
}

window.onclick = function(event) {
  if (event.target == modal) {
    modal.style.display = "none";
  }
}

使用第三方库实现弹窗(以SweetAlert2为例)

安装SweetAlert2库

js实现页面弹窗

npm install sweetalert2

在项目中引入并使用

import Swal from 'sweetalert2'

Swal.fire({
  title: '弹窗标题',
  text: '这里是弹窗内容',
  icon: 'success',
  confirmButtonText: '确定'
})

实现带表单的弹窗

HTML结构

js实现页面弹窗

<button id="showForm">显示表单弹窗</button>
<div id="formModal" class="modal">
  <div class="modal-content">
    <span class="close">&times;</span>
    <form id="myForm">
      <input type="text" placeholder="用户名">
      <input type="password" placeholder="密码">
      <button type="submit">提交</button>
    </form>
  </div>
</div>

JavaScript处理表单提交

const formModal = document.getElementById("formModal");
const formBtn = document.getElementById("showForm");
const formClose = formModal.getElementsByClassName("close")[0];
const myForm = document.getElementById("myForm");

formBtn.onclick = function() {
  formModal.style.display = "block";
}

formClose.onclick = function() {
  formModal.style.display = "none";
}

myForm.onsubmit = function(e) {
  e.preventDefault();
  // 处理表单数据
  formModal.style.display = "none";
}

实现动画效果的弹窗

修改CSS添加动画效果

.modal-content {
  animation: modalopen 0.5s;
}

@keyframes modalopen {
  from {opacity: 0; transform: translateY(-50px)}
  to {opacity: 1; transform: translateY(0)}
}

实现全屏弹窗

修改CSS样式

.modal-content {
  width: 100%;
  height: 100%;
  margin: 0;
  border-radius: 0;
}

标签: 页面js
分享给朋友:

相关文章

js实现轮播图

js实现轮播图

基础轮播图实现 使用HTML、CSS和JavaScript实现一个简单的自动轮播图。HTML结构包含一个容器和多个图片项。 <div class="slider"> <div…

h5实现登录页面跳转

h5实现登录页面跳转

实现登录页面跳转的基本方法 使用HTML5和JavaScript实现登录页面跳转,可以通过表单提交或JavaScript事件触发。以下是几种常见方式: 表单提交跳转 在HTML中创建一个表单,通过a…

h5页面实现录音

h5页面实现录音

实现H5页面录音的方法 使用Web Audio API Web Audio API提供音频处理能力,结合getUserMedia可实现录音。核心步骤包括请求麦克风权限、创建音频上下文和处理音频流。…

vue实现页面刻度

vue实现页面刻度

实现页面刻度的基本思路 在Vue中实现页面刻度通常用于展示进度、测量或标记特定位置。可以通过动态计算和渲染刻度元素来实现,结合CSS样式控制显示效果。 使用动态渲染刻度线 通过v-for指令动态生成…

js实现正交

js实现正交

正交的概念 正交在数学和计算机科学中通常指两个向量垂直或线性无关。在编程中,正交性常被用于设计模块化、低耦合的系统。 向量正交判断 判断两个向量是否正交可以通过点积是否为0来实现: functio…

js实现视口

js实现视口

js实现视口检测的方法 使用JavaScript检测元素是否进入视口(viewport)可以通过Intersection Observer API或手动计算元素位置实现。以下是两种常见方法: Int…