- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 div#leftPosText
元素(图片下方的黑色元素)内放置了一个 -90° 的 p#rot
。我希望“嗨”文本在垂直和水平方向上居中。我发现了与我重复的类似问题,但无论如何我都没有找到解决方案。
这是有问题的代码:
div#leftPosText{
position:absolute;
padding:2vh;
background-color:black;
width:20vw;
height:50vh;
font-size:calc(5vh + 5vw);
text-align:center;
vertical-align:middle;
}
p#rot{
transform:rotate(-90deg);
color:white;
text-align:center;
position: absolute;
margin-left: auto;
margin-right: auto;
left: 0;
right: 0;
}
这是完整的片段(我没有包含图片):
const maxFiles = 159;
const randomEl = document.getElementById("random");
function randombg() {
var random = Math.floor(Math.random() * maxFiles)+1;
randomEl.style.backgroundImage = `url('images/(${random}).jpeg')`;
}
randombg();
*{
overflow-x:hidden;
margin:0;
padding:0;
transition:1s;
}
body,html{
margin:0;
padding:0;
}
#random{
background-position: center center;
background-size: cover;
background-repeat: no-repeat;
left: 0;
right: 0;
bottom: 0;
margin: auto;
min-width: 100vw;
height: 100vh;
background-size:cover;
background-repeat:no-repeat;
background-position:center center;
z-index:-2;
font-size:calc(1vh + 1vw);
height:100vh;
}
p#FrontText{
font-size:calc(5vh + 5vw);
opacity:1;
}
div#headText{
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
background-color:white;
opacity:0.6;
border:1px solid white;
padding:calc(1vh + 1vw);
border-radius:0.1em;
box-shadow:0 0 25px white;
}
div#overlayStart{
position:absolute;
top:0;left;0;
width:100vw;
height:100vh;
z-index:0;
opacity:0.3;
background: -webkit-linear-gradient(221deg, #a1c4fd, #c2e9fb, #cfd9df, #667eea, #764ba2, #e2d1c3, #89f7fe, #66a6ff, #48c6ef, #6f86d6, #feada6, #a3bded, #6991c7, #13547a, #80d0c7, #93a5cf, #434343, #000000, #93a5cf, #ff758c, #868f96, #596164, #c79081, #dfa579, #09203f, #96deda, #50c9c3, #29323c, #485563, #1e3c72, #2a5298, #b7f8db, #50a7c2, #2193b0, #6dd5ed);
background: -o-linear-gradient(221deg, #a1c4fd, #c2e9fb, #cfd9df, #667eea, #764ba2, #e2d1c3, #89f7fe, #66a6ff, #48c6ef, #6f86d6, #feada6, #a3bded, #6991c7, #13547a, #80d0c7, #93a5cf, #434343, #000000, #93a5cf, #ff758c, #868f96, #596164, #c79081, #dfa579, #09203f, #96deda, #50c9c3, #29323c, #485563, #1e3c72, #2a5298, #b7f8db, #50a7c2, #2193b0, #6dd5ed);
background: linear-gradient(229deg, #a1c4fd, #c2e9fb, #cfd9df, #667eea, #764ba2, #e2d1c3, #89f7fe, #66a6ff, #48c6ef, #6f86d6, #feada6, #a3bded, #6991c7, #13547a, #80d0c7, #93a5cf, #434343, #000000, #93a5cf, #ff758c, #868f96, #596164, #c79081, #dfa579, #09203f, #96deda, #50c9c3, #29323c, #485563, #1e3c72, #2a5298, #b7f8db, #50a7c2, #2193b0, #6dd5ed);
-webkit-background-size: 7400% 7400%;
background-size: 7400% 7400%;
-webkit-animation: backgroundGardient 500s ease infinite;
animation: backgroundGardient 200s ease infinite;
}
@-webkit-keyframes backgroundGardient{
0%{
background-position: 0% 83%
}
50%{
background-position: 100% 18%
}
100%{
background-position: 0% 83%
}
}
@keyframes backgroundGardient{
0%{
background-position: 0% 83%
}
50%{
background-position: 100% 18%
}
100%{
background-position: 0% 83%
}
}
div#leftPosText{
position:absolute;
padding:2vh;
background-color:black;
width:20vw;
height:50vh;
font-size:calc(5vh + 5vw);
text-align:center;
vertical-align:middle;
}
p#rot{
transform:rotate(-90deg);
color:white;
text-align:center;
position: absolute;
margin-left: auto;
margin-right: auto;
left: 0;
right: 0;
}
div#mainTextOne{
background-color: #ecf0f1;
width:80vw;
text-align:center;
left:calc(20vw + 4vh);
position:absolute;
}
<Doctype>
<html>
<meta charset='utf-8'>
<head>
</head>
<body>
<div id='random'>
</div>
<div id='overlayStart'></div>
<div id='headText'><p id='FrontText'>Hello!</p></div>
<div id='leftPosText'><p id='rot'>Hi</p></div>
<div id='mainTextOne'>hi</div>
</body>
</html>
最佳答案
如果您将旋转段落的父级 (div#leftPosText
) 设置为 flex 容器并在其上设置对齐方式,则一切就绪。
const maxFiles = 159;
const randomEl = document.getElementById("random");
function randombg() {
var random = Math.floor(Math.random() * maxFiles)+1;
randomEl.style.backgroundImage = `url('images/(${random}).jpeg')`;
}
randombg();
*{
overflow-x:hidden;
margin:0;
padding:0;
transition:1s;
}
body,html{
margin:0;
padding:0;
}
#random{
background-position: center center;
background-size: cover;
background-repeat: no-repeat;
left: 0;
right: 0;
bottom: 0;
margin: auto;
min-width: 100vw;
height: 100vh;
background-size:cover;
background-repeat:no-repeat;
background-position:center center;
z-index:-2;
font-size:calc(1vh + 1vw);
height:100vh;
}
p#FrontText{
font-size:calc(5vh + 5vw);
opacity:1;
}
div#headText{
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
background-color:white;
opacity:0.6;
border:1px solid white;
padding:calc(1vh + 1vw);
border-radius:0.1em;
box-shadow:0 0 25px white;
}
div#overlayStart{
position:absolute;
top:0;left;0;
width:100vw;
height:100vh;
z-index:0;
opacity:0.3;
background: -webkit-linear-gradient(221deg, #a1c4fd, #c2e9fb, #cfd9df, #667eea, #764ba2, #e2d1c3, #89f7fe, #66a6ff, #48c6ef, #6f86d6, #feada6, #a3bded, #6991c7, #13547a, #80d0c7, #93a5cf, #434343, #000000, #93a5cf, #ff758c, #868f96, #596164, #c79081, #dfa579, #09203f, #96deda, #50c9c3, #29323c, #485563, #1e3c72, #2a5298, #b7f8db, #50a7c2, #2193b0, #6dd5ed);
background: -o-linear-gradient(221deg, #a1c4fd, #c2e9fb, #cfd9df, #667eea, #764ba2, #e2d1c3, #89f7fe, #66a6ff, #48c6ef, #6f86d6, #feada6, #a3bded, #6991c7, #13547a, #80d0c7, #93a5cf, #434343, #000000, #93a5cf, #ff758c, #868f96, #596164, #c79081, #dfa579, #09203f, #96deda, #50c9c3, #29323c, #485563, #1e3c72, #2a5298, #b7f8db, #50a7c2, #2193b0, #6dd5ed);
background: linear-gradient(229deg, #a1c4fd, #c2e9fb, #cfd9df, #667eea, #764ba2, #e2d1c3, #89f7fe, #66a6ff, #48c6ef, #6f86d6, #feada6, #a3bded, #6991c7, #13547a, #80d0c7, #93a5cf, #434343, #000000, #93a5cf, #ff758c, #868f96, #596164, #c79081, #dfa579, #09203f, #96deda, #50c9c3, #29323c, #485563, #1e3c72, #2a5298, #b7f8db, #50a7c2, #2193b0, #6dd5ed);
-webkit-background-size: 7400% 7400%;
background-size: 7400% 7400%;
-webkit-animation: backgroundGardient 500s ease infinite;
animation: backgroundGardient 200s ease infinite;
}
@-webkit-keyframes backgroundGardient{
0%{
background-position: 0% 83%
}
50%{
background-position: 100% 18%
}
100%{
background-position: 0% 83%
}
}
@keyframes backgroundGardient{
0%{
background-position: 0% 83%
}
50%{
background-position: 100% 18%
}
100%{
background-position: 0% 83%
}
}
div#leftPosText{
position:absolute;
padding:2vh;
background-color:black;
width:20vw;
height:50vh;
font-size:calc(5vh + 5vw);
display:flex; /* Parent becomes a flex container */
align-items:center; /* Alignment will inherit to children */
}
p#rot{
transform-origin:center center;
transform:rotate(-90deg);
color:white;
text-align:center;
position: absolute;
margin-left: auto;
margin-right: auto;
left: 0;
right: 0;
}
div#mainTextOne{
background-color: #ecf0f1;
width:80vw;
text-align:center;
left:calc(20vw + 4vh);
position:absolute;
}
<Doctype>
<html>
<meta charset='utf-8'>
<head>
</head>
<body>
<div id='random'>
</div>
<div id='overlayStart'></div>
<div id='headText'><p id='FrontText'>Hello!</p></div>
<div id='leftPosText'><p id='rot'>Hi</p></div>
<div id='mainTextOne'>hi</div>
</body>
</html>
关于javascript - 在 div 的中心位置 p,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49695469/
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: How to align a to the middle of the page 这是一个简单的问题,应该有一个简
我想知道如何在屏幕中央的ListView中生成2个itens。 class _CategoriesState extends State { List categories = ["Anterio
我需要修复 UICollectionView 的一个小问题,当在 6s 设备尺寸上时,我得到如下布局: 但是,我想知道将它们居中以使其成为两条线的最佳方法是什么,或者我应该将它们缩小一点以便可以放置其
我尝试在 UIImageView 中居中 CAShapeLayer 但没有成功,我找到了解决方案,将其(CAShapeLayer)添加到 UIVIew,然后将 UIVIew 添加到 ImageView
一直在从线性布局和相对布局切换,因为我想实现图像的居中。 显示图片:
* { margin:0; padding:0; } /** General Style Info **/ body { background: #003d4c; co
我目前正在尝试修改我在 Wordpress 上的 Royal Slider 插件 (http://dimsemenov.com/plugins/royal-slider/) 我的目标是将所有标题的文本
我已经坚持了一段时间,因此简化了我的要求。当您单击标记时,信息窗口将打开,当用户缩放时,我希望该标记位于 map 的中心。这不起作用,但我认为它很接近: function bindInfoWindow
/* Linked Styles */ body { padding: 0 !important;
这个问题在这里已经有了答案: How do I center floated elements? (12 个答案) 关闭 7 年前。
这个问题在这里已经有了答案: Is there an equivalent to background-size: cover and contain for image elements? (1
我试图让我的页眉停留在页面的中间,不管我在什么窗口大小。 我试过使用 Bootstrap。 StackOverflow 还有这个 CSS。 .section-t
我有一个 1600 像素宽的页面。主要区域虽然只有 900 像素宽。我有一个导航应该固定在页面的中心(它是)。我的问题是当我打开页面时,页面固定在左侧而不是在打开时居中。当用户访问该网站时,我需要做什
我正在尝试找到 View 的中心。对于非旋转 View ,该值是正确的,但对于旋转 View ,它不正确,因为中心 (0,0) 正在旋转。在缩放的情况下,即使缩放后宽度和高度也保持不变 我正在使用以下
预期效果是将 Kartennummer 和 Passwort 集中。 这怎么可能? 我为此使用了一个自定义类: import 'package:flutter/material.dart'; impo
我管理着许多 Maven 项目。他们中的大多数部署到我们的内部 maven 存储库。现在我想开始向 Maven Central 发布一个项目。到目前为止,我有一个父 POM,它指定了我们内部存储库的
我试图锚定两个进展,但我看不到获得预期结果的方法。 我希望左边的进度条固定在左边,右边的条固定在中心固定(如下图所示) (下图显示调整大小的表格) 我尝试将控件放在具有各种 anchor 的停靠面板上
我正在玩 Angular 模态 ui 对话框。我想知道有什么方法可以让它居中?我发现了一个类似的问题: Twitter Bootstrap - Center Modal Dialog 但无法使其工作,
是否可以将值标签放置在条形上,使它们位于条形的中心? 如果我设置条形 align: "center",则条形上的标签将关闭且不居中。 $(function() { var d
http://www.asp.net/signalr/overview/signalr-20/getting-started-with-signalr-20/tutorial-signalr-20-s
我是一名优秀的程序员,十分优秀!