我创建了一个包含2个白色侧边栏小部件,灰色文章框和一些彩色按钮的网站。目前,使用left:175px;
的CSS属性#mw-panel
来定位窗口小部件和圈子项,同时使用#right-navigation li a
放置right: 30em;
。
不幸的是,这只在我的特定1080p屏幕上看起来最好。如果浏览器窗口调整大小,则窗口小部件和按钮项开始与主文章重叠。
我尝试将left: 175px;
转换为margin-right: 20px;
,以便小部件在文章之间保持20px的恒定距离。尝试此操作后,我的白色小部件被放置在浏览器窗口的左边缘。然后我试图改变显示:绝对;别的什么,但我没有成功。
为了获得与图片中相同的结果,我需要在代码中进行哪些更改?
#right-navigation li a {
font-size: 14px;
color: white;
text-shadow: 4px 4px 15px #000;
display: block;
padding-left: 60px;
opacity: 0;
-webkit-transition: all .4s cubic-bezier(.4, 0, .2, 2);
transition: all .4s cubic-bezier(.4, 0, .2, 2);
width: 250px;
}
#right-navigation li, #right-navigation li:after {
-webkit-transition: all .2s cubic-bezier(.4, 0, .2, 1);
transition: all .2s cubic-bezier(.4, 0, .2, 1);
}
#right-navigation li:after {
content:'';
width: 10px;
height: 10px;
border-radius: 50%;
left: 20px;
top: 20px;
}
#right-navigation li:hover:after {
width: 50px;
height: 50px;
left: 0;
top: 0;
}
#right-navigation li:hover > li {
transform: rotate(90deg);
}
#right-navigation li:hover a {
opacity: 1;
padding-left: 75px;
}
#right-navigation li{
border-radius: 50%;
margin-top: 10px;
width: 50px;
height: 50px;
box-shadow: 0 0 4px rgba(0, 0, 0, .11), 0 4px 8px rgba(0, 0, 0, .22);
transition: 0.2s opacity;
}
#left-navigation {
position: absolute;
}
#right-navigation{
position:absolute;
right: 30em;
top: 250px;
}
.content .entry {
background-color: #6b6b6b;
}
#mw-panel,#p-personal {
padding: 1em;
background: #fff;
border-radius: 10px;
position: absolute;
left: 175px;
width: 240px;
}
#ca-view{
top: 120px;
background:url('') no-repeat center,radial-gradient(#00FFFF, #00878E);}
#ca-ve-edit{
top: 180px;
background:url('') no-repeat center, radial-gradient(yellow, #BD9D01);
}
#ca-edit,#ca-viewsource{
top: 240px;
background:url('') no-repeat center, radial-gradient(orange, #B75D00);
}
.site-inner,
.wrap{margin:0 auto;max-width:1200px;}
.site-inner{clear:both;padding-top:40px;}
body {
background-image: linear-gradient(#434343, #282828);
color: #555;
font-family: Open Sans, sans-serif;
font-size: 14px;
line-height: 24px;
margin: 0;
}

<body class="full-width-content">
<link rel="stylesheet" id="child-theme-css" href="https://vocaloid.de/wp-content/themes/Vuturize/style.css" type="text/css" media="all">
<div id="mw-panel">
<div class="portal" role="navigation" id='p-navigation' aria-labelledby='p-navigation-label'>
<h3 id='p-navigation-label'>Box1</h3>
TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST
</div>
</div>
<div class="site-inner">
<div class="content-sidebar-wrap">
<main class="content">
<article id="content" class="page type-page entry">
<h1>Demo</h1>
<div id="bodyContent" class="mw-body-content">
<div id="jump-to-nav" class="mw-jump">
<a href="#mw-head">Navigation</a>
</div>
</div>
</article>
</main>
</div>
<div id="mw-head">
<div id="p-personal" role="navigation" class="" aria-labelledby="p-personal-label">
<h3 id="p-personal-label">Box2</h3>
TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST</div>
<div id="right-navigation">
<div id="p-views" role="navigation" class="vectorTabs" aria-labelledby="p-views-label">
<h3 id="p-views-label">Ansichten</h3>
<ul>
<li id="ca-view" class="selected">
</li>
<li id="ca-ve-edit">
</li>
</ul>
</div>
</div>
</div>
</div>
&#13;
答案 0 :(得分:0)
将此类添加到.site-inner以对齐屏幕的容器中心。
.site-inner{
margin-left: auto;
margin-right: auto;
}
答案 1 :(得分:0)
而不是使用px
像素特定尺寸,而是使用%
或em
尺寸。
您还可以使用CSS @media
查询选择器通过设置em
来设置body{font-size:**px}
大小的基础(其中*是基于当前显示/窗口大小的一小部分的数字)。
这将设置响应式布局的基础,您的内容也会相应缩放。
如果您需要高度可扩展的解决方案,而是尝试在SVG中构建内容,并让SVG元素在SVG元素根目录上具有min-width
和min-height
属性,这将防止事情变得太小
这是SVG解释的一个例子:
<svg
xmlns="http://www.w3.org/2000/svg"
version="1.1"
width="100%"
height="100%"
viewBox="0 0 1920 1080"
style="display:block; min-width:640px; min-height:360px">
... The rest of your code here ...
</svg>
如上所示,上面的效果非常好,您可以看到,分辨率基于您当前的分辨率,但会完美缩放并保持较小(或更大)分辨率/显示器的比例。
唯一的缺点是你必须在SVG中做所有事情,这不是一件坏事,但如果要求另有规定则可能是一个问题。
虽然优势很大,因为您可以使用SVG编辑器构建交互式组件,例如&#34; Inkscape&#34; (免费),然后保存,并在网络浏览器中查看您的模型 - 粗略节省了大量时间,而不是手动编码一切。