前端JS按钮点击事件、跳出弹窗、遮罩的实战示例

news2025/3/14 20:48:02

前端JS 按钮事件、弹窗、遮罩实战示例

文章目录

  • 前端JS 按钮事件、弹窗、遮罩实战示例
  • 一、开始
  • 二、功能实现
  • 三、具体代码如下
    • 1、运行结果
    • 2、具体代码如下
  • 四、功能解析
    • 1、index.html
    • 2、button.css
    • 3、server.js

一、开始

各位未来的开发者请上座,闲暇的时候发现,这一块好像能做一个简单的实战示例,遂写了写。

二、功能实现

功能描述:

  1. 两个按键,登录按键和注册按钮
  2. 初始颜色背景是浅灰色,按键是黑色。
  3. 点击后按键背景变为天蓝色,内容文字变为白色
  4. 同时中间跳出弹窗显示登录/注册成功。
  5. 等待2秒或者点击遮罩弹窗关闭

三、具体代码如下

1、运行结果

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

2、具体代码如下

下面的代码可以直接运行

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<meta name="viewport" content="width=device-width, initial-scale=1.0">
		<title>登录注册示例</title>
		<style>
			.button {
			    background-color: lightgrey; /* 初始背景颜色 */
			    color: black; /* 初始文字颜色 */
			    padding: 10px 20px;
			    border: none;
			    border-radius: 5px;
			    cursor: pointer;
			    transition: background-color 0.3s, color 0.3s; /* 过渡效果 */
			  }
			  .button.active {
			    background-color: skyblue; /* 激活状态背景颜色 */
			    color: white; /* 激活状态文字颜色 */
			  }
			  .modal {
			    display: none; /* 默认不显示 */
			    position: fixed;
			    left: 50%;
			    top: 50%;
			    transform: translate(-50%, -50%);
			    padding: 20px;
			    border: 1px solid #ddd;
			    background-color: white;
			    z-index: 1000;
			  }
			  .overlay {
			    display: none; /* 默认不显示 */
			    position: fixed;
			    top: 0;
			    left: 0;
			    width: 100%;
			    height: 100%;
			    background-color: rgba(0, 0, 0, 0.5); /* 半透明背景 */
			    z-index: 999;
			  }
		</style>
	</head>
	<body>

		<button id="loginButton" class="button">登录</button>
		<button id="registerButton" class="button">注册</button>

		<div id="modal" class="modal">
			<p id="modalContent">登录成功</p>
		</div>

		<div id="overlay" class="overlay"></div>

		<script>
			// 获取元素
			  var loginButton = document.getElementById('loginButton');
			  var registerButton = document.getElementById('registerButton');
			  
			  var modal = document.getElementById('modal');
			  var overlay = document.getElementById('overlay');
			  var modalContent = document.getElementById('modalContent');
			
			  // 登录按钮点击事件
			  loginButton.addEventListener('click', function() {
			    modalContent.textContent = '登录成功'; // 设置弹窗内容
			    showModal();
			    this.classList.add('active'); // 添加激活状态的样式
			  });
			
			  // 注册按钮点击事件
			  registerButton.addEventListener('click', function() {
			    modalContent.textContent = '注册成功'; // 设置弹窗内容
			    showModal();
			    this.classList.add('active'); // 添加激活状态的样式
			  });
			
			  // 显示弹窗和遮罩层
			  function showModal() {
			    modal.style.display = 'block';
			    overlay.style.display = 'block';
			    setTimeout(function() {
			      modal.style.display = 'none';
			      overlay.style.display = 'none';
			      resetButtons(); // 2秒后隐藏弹窗和遮罩层,并重置按钮
			    }, 2000);
			  }
			
			  // 重置按钮样式
			  function resetButtons() {
			    loginButton.classList.remove('active');
			    registerButton.classList.remove('active');
			  }
			
			  // 点击遮罩层也可以关闭弹窗
			  overlay.addEventListener('click', function() {
			    modal.style.display = 'none';
			    overlay.style.display = 'none';
			    resetButtons();
			  });
		</script>

	</body>
</html>

四、功能解析

为了方便大家学习,对这个简短的程序进行一下拆解
我将其拆解为三个文件,这三个文件说白了就是把最开始上面的那坨拆分前端三件套:Html,CSS,JS。

1、index.html

index的程序结构相对简洁
实现功能:

  1. 设置两个按钮登录与注册
  2. 设置一个div 包裹一个文本。文本初始内容随意(后面会改)(弹窗)
  3. 设置一个空div (遮罩)
  4. 导入button.css和server.js

注:弹窗和遮罩一开始需要设置好,然后一开始再隐藏起来
依据上述功能理念,设置代码如下

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<meta name="viewport" content="width=device-width, initial-scale=1.0">
		<title>登录注册示例</title>
		<link rel="stylesheet" href="button.css">
	</head>

	<body>

		<button id="loginButton" class="button">登录</button>
		<button id="registerButton" class="button">注册</button>

		<div id="modal" class="modal">
			<p id="modalContent">登录成功</p>
		</div>

		<div id="overlay" class="overlay"></div>

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

2、button.css

.button {
  background-color: lightgrey; /* 初始背景颜色 */
  color: black; /* 初始文字颜色 */
  padding: 10px 20px;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s, color 0.3s; /* 过渡效果 */
}
.button.active {
  background-color: skyblue; /* 激活状态背景颜色 */
  color: white; /* 激活状态文字颜色 */
}
.modal {
  display: none; /* 默认不显示 */
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  padding: 20px;
  border: 1px solid #ddd;
  background-color: white;
  z-index: 1000;
}
.overlay {
  display: none; /* 默认不显示 */
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5); /* 半透明背景 */
  z-index: 999;
}

下面简单讲一下这些样式的各项功能设置的作用,不需要的同学跳过即可

按键 button样式解析

background-color: lightgrey;:设置按钮的背景颜色为浅灰色(lightgrey)。

color: black;:设置按钮文字的颜色为黑色。

padding: 10px 20px;:设置按钮内容与按钮边框之间的内边距,上下为10像素,左右为20像素。

border: none;:设置按钮没有边框。

border-radius: 5px;:设置按钮的边框圆角半径为5像素,使按钮的边角变得圆润。

cursor: pointer;:设置鼠标悬停在按钮上时的光标样式为手型,表示该区域可以点击。

transition: background-color 0.3s, color
0.3s;:这一行定义了按钮背景颜色和文字颜色的过渡效果。当按钮的背景颜色或文字颜色发生变化时,变化会在0.3秒内平滑地过渡,而不是突然改变,给用户带来更流畅的视觉体验。

样式解析汇总:这些样式属性一起定义了一个简洁而有吸引力的按钮样式,使按钮看起来更加现代化和易于与用户交互。

.button.active样式解析:激活样式就简单改一下背景和字体颜色

弹窗样式 .modal样式解析

display: none;:设置元素不显示,即在页面上不可见。这通常用于隐藏元素,可以通过 JavaScript 或其他方式来控制显示。

position: fixed;:设置元素的定位方式为固定定位,元素相对于浏览器窗口固定位置,不随页面滚动而移动。

left: 50%;:将元素左边缘定位在距离父元素左边缘50%的位置,即居中水平定位。

top: 50%;:将元素上边缘定位在距离父元素顶部50%的位置,即居中垂直定位。

transform: translate(-50%, -50%);:使用 transform 属性的 translate
函数将元素向左和向上移动自身宽度和高度的50%,以便实现水平和垂直居中定位。

padding: 20px;:设置元素内容与元素边框之间的内边距为20像素。

border: 1px solid #ddd;:设置元素的边框为1像素宽的实线边框,颜色为淡灰色(#ddd)。

background-color: white;:设置元素的背景颜色为白色。

z-index: 1000;:设置元素在层叠顺序中的位置为1000,使其位于具有较低 z-index 值的元素之上。

样式解析汇总:这段代码描述了一个在页面中居中显示、具有白色背景、灰色边框和一定内边距的固定定位元素,且在层叠顺序中处于较高的位置。

遮罩 .overlay 样式解析: 基本属性上面都讲过了,参考理解即可就不赘述了。

3、server.js

下面是JS部分

  1. 获取登录,注册按键的对象。获取弹窗,弹窗内容,遮罩的对象,方便操作设计函数:getElementById()
  2. 登录/注册按键添加点击事件:(1)修改弹窗内容为登录/注册成功、(2)显示弹窗、(3)登录按键添加激活样式
  3. 添加遮罩点击事件:弹窗、遮罩隐藏,去除登录,注册上面的激活样式

注:隐藏方法:设置样式style.display = ‘none’,显示方法:设置style.display = ‘block’;
然后就没啥难点,就按部就班写完脚本即可


 // 显示弹窗和遮罩层
 function showModal() {
   modal.style.display = 'block';
   overlay.style.display = 'block';
   setTimeout(function() {
     modal.style.display = 'none';
     overlay.style.display = 'none';
     resetButtons(); // 2秒后隐藏弹窗和遮罩层,并重置按钮
   }, 2000);
 }

 // 重置按钮样式
 function resetButtons() {
   loginButton.classList.remove('active');
   registerButton.classList.remove('active');
 }

	// 获取元素
  var loginButton = document.getElementById('loginButton');
  var registerButton = document.getElementById('registerButton');
  
  var modal = document.getElementById('modal');
  var overlay = document.getElementById('overlay');
  var modalContent = document.getElementById('modalContent');
 
  // 登录按钮点击事件
  loginButton.addEventListener('click', function() {
    modalContent.textContent = '登录成功'; // 设置弹窗内容
    showModal();
    this.classList.add('active'); // 添加激活状态的样式
  });
 
  // 注册按钮点击事件
  registerButton.addEventListener('click', function() {
    modalContent.textContent = '注册成功'; // 设置弹窗内容
    showModal();
    this.classList.add('active'); // 添加激活状态的样式
  });
 
  // 点击遮罩层也可以关闭弹窗
  overlay.addEventListener('click', function() {
    modal.style.display = 'none';
    overlay.style.display = 'none';
    resetButtons();
  });

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1453476.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

蓝桥杯:C++二分算法

在基本算法中&#xff0c;二分法的应用非常广泛&#xff0c;它是一种思路简单、编程容易、效率极高的算法。蓝桥杯软件类大赛中需要应用二分法的题目很常见。 二分法有整数二分和实数二分两种应用场景 二分法的概念 二分法的概念很简单&#xff0c;每次把搜索范围缩小为上一…

普中51单片机学习(六)

点亮第一个LED LED相关知识 LED,即发光二极管&#xff0c;是一种半导体固体发光器件。工作原理为&#xff1a;LED的工作是有方向性的&#xff0c;只有当正级接到LED阳极&#xff0c;负极接到LED的阴极的时候才能工作&#xff0c;如果反接LED是不能正常工作的。其原理图如下 …

linux系统监控工具prometheus的安装以及监控mysql

prometheus 安装服务端客户端监控mysql prometheus浏览器查看 安装 https://prometheus.io/download/下载客户端和服务端以及需要监控的所有的包服务端 官网下载下载prometheustar -xf prometheus-2.47.2.linux-amd64.tar.gz -C /usr/local/ cd /usr/local/ mv prometheus-2.…

如何理解CSS的边框宽度?

CSS 边框宽度学习手记 CSS 边框宽度小概念 在CSS的世界里&#xff0c;border-width这个属性真的很实用&#xff0c;它能帮我指定HTML元素四周边框的宽度。这个宽度嘛&#xff0c;可以用像素px、点pt、厘米cm、相对单位em这些来表示&#xff0c;很方便吧&#xff01;还有呢&am…

代码随想录 Leetcode435. 无重叠区间

题目&#xff1a; 代码(首刷看解析 2024年2月17日&#xff09;&#xff1a; class Solution { private:const static bool cmp(vector<int>& a,vector<int>& b) {return a[0] < b[0];} public:int eraseOverlapIntervals(vector<vector<int>&…

XUbuntu22.04之apt与snap如何重装软件(二百一十二)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

[AIGC_coze] Kafka 的主题分区之间的关系

Kafka 的主题分区之间的关系 在 Kafka 中&#xff0c;主题&#xff08;Topics&#xff09;和分区&#xff08;Partitions&#xff09;是两个重要的概念&#xff0c;它们之间存在着密切的关系。 主题是 Kafka 中用于数据发布和订阅的逻辑单元。每个主题可以包含多个分区&#x…

《学成在线》微服务实战项目实操笔记系列(P92~P120)【下】

史上最详细《学成在线》项目实操笔记系列【下】&#xff0c;跟视频的每一P对应&#xff0c;全系列18万字&#xff0c;涵盖详细步骤与问题的解决方案。如果你操作到某一步卡壳&#xff0c;参考这篇&#xff0c;相信会带给你极大启发。 四、课程发布模块 4.1 (课程发布)模块需求…

Ubuntu学习笔记-Ubuntu搭建禅道开源版及基本使用

文章目录 概述一、Ubuntu中安装1.1 复制下载安装包路径1.2 将安装包解压到ubuntu中1.3 启动服务1.4 设置开机自启动 二、禅道服务基本操作2.1 启动&#xff0c;停止&#xff0c;重启&#xff0c;查看服务状态2.2 开放端口2.3 访问和登录禅道 卜相机关 卜三命、相万生&#xff0…

天锐绿盾|防泄密系统|计算机文件数据\资料安全管理软件

“天锐绿盾”似乎是一款专注于防泄密和计算机文件数据/资料安全管理的软件。在信息安全日益受到重视的今天&#xff0c;这样的软件对于保护企业的核心数据资产和防止敏感信息泄露至关重要。 通用地址&#xff1a;www.drhchina.com 防泄密系统的主要功能通常包括&#xff1a; 文…

Android 12.0 MTK Camera2 设置默认拍照尺寸功能实现

1.前言 在12.0的系统rom定制化开发中,在mtk平台的camera2关于拍照的一些功能修改中,在一些平台默认需要设置最大的分辨率 来作为拍照的分辨率,所以就需要了解拍照尺寸设置流程,然后来实现相关的功能 如图: 2.MTK Camera2 设置默认拍照尺寸功能实现的核心类 \vendor\me…

七、ActiveMQ的传输协议

ActiveMQ的传输协议 一、是什么二、协议1.TCP(默认)2.NIO3.AMQP4.STOMP5.SSL6.MQTT7 WS 三、NIO配置案例1.修改activemq.xml2.重启3.生产者/消费者4.性能提升4.1 配置4.2 生产者/消费者 一、是什么 官网地址&#xff1a;http://activemq.apache.org/configuring-version-5-tra…

印度基金低风险套利回顾

2024年1月19日当天&#xff0c;印度基金(164824)开放申购&#xff0c;限额申购100元&#xff0c;当天溢价率13%左右&#xff0c;这个溢价率已经非常可观了&#xff0c;当然要祭出一拖七大法搞它一把&#xff01; 一拖七套利原理简介 详细的原理和方法可自行在雪球搜索&#…

MCU中断控制

目录 一、中断相关基础知识 1、NVIC&#xff1a;嵌套向量中断控制器 2、可屏蔽中断和不可屏蔽中断的区别 3、中断优先级 4、常见特殊中断 二、中断相关寄存器 三、中断使用步骤&#xff1a; 一、中断相关基础知识 1、NVIC&#xff1a;嵌套向量中断控制器 (1) 它是内核的…

探索MacOS:苹果电脑的操作系统的魅力

引言&#xff1a; 当我们谈论优雅、简洁和高效的操作系统时&#xff0c;MacOS无疑是众多选择中的佼佼者。作为苹果电脑的专有操作系统&#xff0c;MacOS以其独特的用户界面、强大的性能和丰富的生态系统赢得了全球用户的喜爱。本文将带您深入了解MacOS的魅力所在&#xff0c;以…

linux系统---防火墙

目录 一、防火墙的认识 1.防火墙定义 2.防火墙分类 二、Linux系统防火墙 1.Netfilter 2.防火墙工具介绍 2.1iptables 2.2firewalld 2.3nftables 2.4netfilter的五个勾子函数和报文流向 2.4.1五个勾子 2.4.2三种报文流向 3.iptables 3.1iptables概述 3.2iptables…

React -- 组件通信

A-B 父子通信B-C 兄弟通信A-E 跨层通信 父子通信-父传子 基础实现 **实现步骤 ** 父组件传递数据 - 在子组件标签上绑定属性子组件接收数据 - 子组件通过props参数接收数据 function Son(props){return <div>{ props.name }</div> }function App(){const name …

模仿 STM32 驱动开发格式实验

1.模仿 STM32 寄存器定义 为了开发方便&#xff0c; ST 官方为 STM32F103 编写了一个叫做 stm32f10x.h 的文件&#xff0c;在这个文件 里面定义了 STM32F103 所有外设寄存器&#xff0c;我们可以使用其定义的寄存器来进行开发&#xff0c;比如我 们可以用如下代码来初始…

订餐|网上订餐系统|基于springboot的网上订餐系统设计与实现(源码+数据库+文档)

网上订餐系统目录 目录 基于springboot的网上订餐系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、用户功能模块的实现 &#xff08;1&#xff09;用户注册界面 &#xff08;2&#xff09;用户登录界面 &#xff08;3&#xff09;菜品详情界面 &#xff08…

Day-01-02

项目框架搭建 1. 创建父工程 父工程&#xff1a;xuecheng-plus-parent 父工程中没有代码&#xff0c;不用去依赖其它的包&#xff0c;它的作用是限定其它子工程依赖包的版本号&#xff0c;在dependencyManagement 中去编辑即可。 在父工程中只需保留pom.xml文件以及自动生成…