CSS 如何将模态框的内容框居中显示在任何屏幕上

CSS 如何将模态框的内容框居中显示在任何屏幕上

简介

CSS是层叠样式表的缩写。它是一种用于描述标记语言文档呈现方式的样式语言。

使用CSS定位元素,您可以将模态框的内容框居中显示在任何屏幕上。将position属性设置为”absolute”,然后利用top和left属性将元素居中显示是一种实现的方法。left和top属性应设置为50%。

方法

使用各种不同的CSS技术,可以将任何屏幕的中心与模态框的内容框对齐。它们包括−

  • 使用position属性和top和left属性

  • 使用Flexbox

现在让我们详细看一下每种方法及其示例。

方法1:使用“position属性和top和left属性”

这种方法首先通过将position属性设置为”absolute”,然后使用top和left属性将元素居中显示在屏幕上。left和top属性应设置为50%。当您希望元素完全居中时,使用transform属性和值”translate(-50%, -50%)”。

示例

这里,我们将逐步演示如何实现此方法−

步骤1 − 在项目目录(index.html)中创建一个HTML文件。

步骤2 − 在HTML文件中,为模态窗口中的内容框创建一个容器元素。这可以是一个具有CSS可以定位的类或id的div元素。

<div class="modal">
   <p>Modal content goes here...</p>
</div>

步骤3 - 将模态框的内容框的位置属性设置为”absolute”。

.modal {
   position: absolute;
}

步骤4 − 要将模态内容框放在屏幕中心,使用top和left属性。left和top属性应该设置为50%。

.modal {
   position: absolute;
   top: 50%;
   left: 50%;
}

步骤5 − 要使元素完美居中,使用transform属性和值”translate(-50%, -50%)”。

.modal {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
}

步骤6 - 对于模态内容框,您还可以指定宽度和高度;这样做将决定它是作为对话框还是模态框显示。

.modal {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   width: 300px;
   height: 200px;
}

步骤7 − 要使其看起来像一个模态窗口,您可以应用某些CSS样式,如背景颜色、内边距、边框和阴影。

.modal {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   width: 300px;
   height: 200px;
   background-color: white;
   padding: 20px;
   border: 1px solid black;
   box-shadow: 10px 10px 5px #888888;
}

步骤8 − 最终的代码将如下所示 −

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta http-equiv="X-UA-Compatible" content="IE=edge">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <title>Document</title>
   <style>
      .modal {
         position: absolute;
         top: 50%;
         left: 50%;
         transform: translate(-50%, -50%);
         /* additional styles for the modal */
      }
      .modal {
         width: 500px;
         height: 400px;
         background-color: #ffffff;
         border: 1px solid #cccccc;
         padding: 20px;
         position: absolute;
         top: 50%;
         left: 50%;
         transform: translate(-50%, -50%);
         box-shadow: 0px 0px 10px #cccccc;
         border-radius: 10px;
         z-index:1000;
      }
   </style>
</head>
<body>
   <div id="modal" class="modal">
      <!-- modal content here -->
   </div>
   <script>
      window.onresize = function() {
         var modal = document.getElementById("modal");
         var top = (window.innerHeight - modal.offsetHeight) / 2;
         var left = (window.innerWidth - modal.offsetWidth) / 2;
         modal. style.top = top + "px";
         modal. style. left = left + "px";
      }
   </script>
</body>
</html>

方法2:使用FlexBox

FlexBox提供了一种快速的方法来使组件居中显示。要同时水平和垂直对齐元素,可以使用align-items和justify-content属性。

示例

下面,我们将逐步介绍实现这种方法的示例-

步骤1 - 在项目目录中创建一个HTML文件(index.html)。

步骤2 - 在Html文件中,为弹出窗口的内容框创建一个容器元素。这可以是一个带有类或ID的div元素,供CSS选择器使用。

<div class="modal-container">
   <div class="modal">
      <p>Modal content goes here...</p>
   </div>
</div>

步骤3 - 使用设置了align-items属性为center和justify-content属性为center的模态框的父容器。

.modal-container {
   display: flex;
   align-items: center;
   justify-content: center;
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
}

步骤4 - 使用模态框的父容器的align-items和justify-content属性,都设置为center。

.modal {
   width: 300px;
   height: 200px;
}

步骤5 − 你可以应用一些CSS样式,如背景颜色、边距、边框和阴影,使其看起来像一个模态框。

.modal {
   width: 300px;
   height: 200px;
   background-color: white;
   padding: 20px;
   border: 1px solid black;
   box-shadow: 10px 10px 5px #888888;
}

步骤6 − 最终的代码将会像这样 −

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta http-equiv="X-UA-Compatible" content="IE=edge">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <title>Document</title>
   <style>
      .modal-container {
         display: flex;
         align-items: center;
         justify-content: center;
         position: fixed;
         top: 0;
         left: 0;
         width: 100%;
         height: 100%;
         background-color: rgba(0,0,0,0.5);
      }
      .modal {
         background-color: white;
         padding: 20px;
         border-radius: 10px;
         width: 500px;
         height: 400px;
         box-shadow: 0px 0px 10px #cccccc;
      }
   </style>
</head>
<body>
   <div class="modal-container">
      <div class="modal">
         <!-- modal content here -->
      </div>
   </div>
   <script>
      window.onresize = function() {
         var modalContainer = document.getElementsByClassName("modal-container")[0];
         modalContainer.style.height = window.innerHeight + "px";
         modalContainer.style.width = window.innerWidth + "px";
      }
      function showModal(){
         var modalContainer = document.getElementsByClassName("modal-container")[0];
         modalContainer.style.display = "flex";
      }
      function hideModal(){
         var modalContainer = document.getElementsByClassName("modal-container")[0];
         modalContainer.style.display = "none";
      }
   </script>
</body>
</html>

结论

网页开发的一个重要组成部分是将模态内容框居中显示在屏幕上。在本文中,我们探讨了多种方式,包括使用CSS Grid布局、CSS变换、定位属性、top和left属性、Flexbox和Grid布局。记住布局仅仅是模态框的一个组成部分,为了使模态框正常工作,必须提供JavaScript代码。

Camera课程

Python教程

Java教程

Web教程

数据库教程

图形图像教程

办公软件教程

Linux教程

计算机教程

大数据教程

开发工具教程

CSS 精选笔记