Html 使用列和行布局应用Flexbox
我想知道你们是否能帮忙。自从我坐下来从头开始创建一个网站已经有几年了,我只是想做点什么 简单。我知道并在过去使用过断点,但看起来Flexbox可能是一种替代方法(?)。我还没有意识到这一点,我发现将其应用到我的代码中有点棘手 在我的布局中,我有两个堆叠的行:标题和导航链接, 然后在下面的两列中显示主要内容,最后在下面的一行中显示页脚 我把我(正在工作)html页面上的body标签和下面的CSS之间的所有内容都包括在内。现在的一切都是以像素为单位的。如果您能给我一些关于我所做的对与错的建议(例如,我是否使用了太多的容器等),以及如何将Flexbox应用于此,我将不胜感激 谢谢Html 使用列和行布局应用Flexbox,html,css,flexbox,two-column-layout,Html,Css,Flexbox,Two Column Layout,我想知道你们是否能帮忙。自从我坐下来从头开始创建一个网站已经有几年了,我只是想做点什么 简单。我知道并在过去使用过断点,但看起来Flexbox可能是一种替代方法(?)。我还没有意识到这一点,我发现将其应用到我的代码中有点棘手 在我的布局中,我有两个堆叠的行:标题和导航链接, 然后在下面的两列中显示主要内容,最后在下面的一行中显示页脚 我把我(正在工作)html页面上的body标签和下面的CSS之间的所有内容都包括在内。现在的一切都是以像素为单位的。如果您能给我一些关于我所做的对与错的建议(例如,
body {
background-color: #C4C4C4;
font-family: 'Roboto', serif;
/*font-size: 48px;*/
line-height: 25px;
}
#page-container {
margin: 0 auto;
width: 793px;
}
header {
background: url("../images/big-banner.jpg");
background-size: 793px 285px;
background-repeat: no-repeat;
height: 285px;
/*height: 285px;*/
}
header h1 {
padding: 70px 0 0 20px;
color: #FFFFFF;
font-size: 2.8em;
}
header p {
padding: 25px 0 0 20px;
color: #FFFFFF;
font-size: 1.4em;
}
h2 {
font-size: 1.4em;
font-weight: bold;
padding-bottom: 20px;
}
h3 {
font-size: 1em;
font-weight: bold;
padding-bottom: 20px;
}
p {
line-height: 1.7;
padding-bottom: 30px;
}
ul {
padding-left: 20px;
}
li {
list-style-type: disc;
line-height: 2em;
padding-left: 5px;
}
nav ul {
list-style-type: none;
margin: 0;
padding: 0;
overflow: hidden;
background-color: #605A52;
}
nav li {
float: left;
list-style-type: none;
padding: 0;
}
nav li a {
display: block;
color: #FFFFFF;
text-align: center;
font-size: 1em;
padding: 8px 15px 8px 15px;
text-decoration: none;
}
nav li a:hover {
color: #000000;
background-color: #FFFFFF;
}
strong {
font-weight: bold;
}
small {
font-size: 0.9em;
}
section {
}
article {
}
.contact-box {
height: 200px;
width: 200px;
background-color: #FFFFFF;
padding: 15px;
-webkit-box-shadow: -1px 3px 4px 0px rgba(102,102,102,0.73);
-moz-box-shadow: -1px 3px 4px 0px rgba(102,102,102,0.73);
box-shadow: -1px 3px 4px 0px rgba(102,102,102,0.73);
}
summary {
}
.content-container {
width: 793px;
width: 100%;
height: 100%;
display: flex;
}
/* left col */
.left-col {
padding: 40px 20px 60px 60px;
width: 450px;
float: left;
}
/* wull-width left col for contact page */
.full {
width: 100%;
padding-right: 40px;
}
/* right col */
.right-col {
background-color:#FFFFFF;
width: 243px;
float: left;
align-items: stretch;
height: 100%;
padding: 40px 20px 10px 20px;
margin: 10px 0 0 0;
}
.zebra-1, .zebra-2 {
text-align: justify;
margin: 10px 0 10px 0;
}
.zebra-1 {
background-color: #EDEDED;
}
.zebra-2 {
background-color: #FFFFFF;
}
.list-left, .list-right {
text-align: left;
float: left;
width: 43%;
padding-right: 5px;
}
footer {
clear:both;
background-color: #605A52;
padding-left: 10px;
color:#FFFFFF;
}
footer p {
padding: 10px;
}
<div id="page-container">
<header>
<h1>Main title here</h1>
<p>Sub title</p>
</header>
<nav role="navigation">
<ul>
<li><a href="#">Link 1</a></li>
<li><a href="#">Link 1</a></li>
<li><a href="#">Link 1</a></li>
<li><a href="#">Link 1</a></li>
<li><a href="#">Link 1</a></li>
</ul>
</nav>
<div class="content-container zebra-1">
<section class="left-col" role="main">
<h2>Welcome</h2>
<p>Lorem ipsum
</p>
<p>Lorem ipsum
</p>
</section>
<div class="right-col zebra-1" role="complementary">
<aside><div class="contact-box">Contact info here</div></aside>
</div>
</div>
<div class="content-container zebra-2">
<section class="left-col" role="main">
<h2>Another header</h2>
<p>Lorem ipsum
</p>
</section>
<div class="right-col zebra-2" role="complementary">
<p>More stuff here</p>
</div>
</div>
<footer>
<p>
<small>Copyright info</small>
</p>
</footer>
</div>
正文{
背景色:#C4;
字体系列:“Roboto”,衬线;
/*字体大小:48px*/
线高:25px;
}
#页面容器{
保证金:0自动;
宽度:793px;
}
标题{
背景:url(“../images/big banner.jpg”);
背景尺寸:793px285像素;
背景重复:无重复;
高度:285px;
/*高度:285px*/
}
收割台h1{
填充:70px 0 20px;
颜色:#FFFFFF;
字号:2.8em;
}
标题p{
填充:25px 0 20px;
颜色:#FFFFFF;
字号:1.4em;
}
氢{
字号:1.4em;
字体大小:粗体;
垫底:20px;
}
h3{
字号:1em;
字体大小:粗体;
垫底:20px;
}
p{
线高:1.7;
填充底部:30px;
}
保险商实验室{
左侧填充:20px;
}
李{
列表样式类型:disc;
线高:2米;
左侧填充:5px;
}
导航ul{
列表样式类型:无;
保证金:0;
填充:0;
溢出:隐藏;
背景色:#605A52;
}
李海军{
浮动:左;
列表样式类型:无;
填充:0;
}
李娜{
显示:块;
颜色:#FFFFFF;
文本对齐:居中;
字号:1em;
填充:8px 15px 8px 15px;
文字装饰:无;
}
导航李a:悬停{
颜色:#000000;
背景色:#FFFFFF;
}
强{
字体大小:粗体;
}
小的{
字号:0.9em;
}
部分{
}
文章{
}
.通讯录{
高度:200px;
宽度:200px;
背景色:#FFFFFF;
填充:15px;
-网络工具包盒阴影:-1px 3px 4px 0px rgba(102102,0.73);
-莫兹盒阴影:-1px 3px 4px 0px rgba(102102,0.73);
盒影:-1px 3px 4px 0px rgba(102102,0.73);
}
总结{
}
.内容容器{
宽度:793px;
宽度:100%;
身高:100%;
显示器:flex;
}
/*左列*/
.左栏{
填充:40px 20px 60px 60px;
宽度:450px;
浮动:左;
}
/*联系人页面的左栏宽度*/
.满{
宽度:100%;
右边填充:40px;
}
/*右柱*/
.右上校{
背景色:#FFFFFF;
宽度:243px;
浮动:左;
对齐项目:拉伸;
身高:100%;
填充:40px 20px 10px 20px;
利润率:10px0;
}
.斑马-1、.斑马-2{
文本对齐:对齐;
利润率:10px 0 10px 0;
}
.斑马-1{
背景色:#EDEDED;
}
.斑马-2{
背景色:#FFFFFF;
}
.list left、.list right{
文本对齐:左对齐;
浮动:左;
宽度:43%;
右侧填充:5px;
}
页脚{
明确:两者皆有;
背景色:#605A52;
左侧填充:10px;
颜色:#FFFFFF;
}
页脚p{
填充:10px;
}
主标题在这里
副标题
欢迎
同侧眼睑
同侧眼睑
联系信息在此
另一个标题
同侧眼睑
这里有更多的东西
版权信息
这可能会对您有所帮助。使用flex时,不需要指定左右列的宽度,也不需要浮动
尝试这样做,您将了解flex是如何工作的
首先,我为其他浏览器添加了适当的flex声明:
.content-container {
width: 793px;
width: 100%;
height: 100%;
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-ms-flex-flow: wrap;
-webkit-flex-flow: wrap;
flex-flow: wrap;
}
第二,更改您的左右列:
/* left col */
.left-col {
padding: 40px 20px 60px 60px;
flex: 0 0 25%;
-webkit-flex: 0 0 25%;
-ms-flex: 0 0 25%;
}
/* right col */
.right-col {
background-color:#FFFFFF;
align-items: stretch;
height: 100%;
padding: 40px 20px 10px 20px;
margin: 10px 0 0 0;
flex: 0 0 25%;
-webkit-flex: 0 0 25%;
-ms-flex: 0 0 25%;
}
尝试更改%后,您就会明白这一点 这可能会对你有所帮助。使用flex时,不需要指定左右列的宽度,也不需要浮动 尝试这样做,您将了解flex是如何工作的 首先,我为其他浏览器添加了适当的flex声明:
.content-container {
width: 793px;
width: 100%;
height: 100%;
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-ms-flex-flow: wrap;
-webkit-flex-flow: wrap;
flex-flow: wrap;
}
第二,更改您的左右列:
/* left col */
.left-col {
padding: 40px 20px 60px 60px;
flex: 0 0 25%;
-webkit-flex: 0 0 25%;
-ms-flex: 0 0 25%;
}
/* right col */
.right-col {
background-color:#FFFFFF;
align-items: stretch;
height: 100%;
padding: 40px 20px 10px 20px;
margin: 10px 0 0 0;
flex: 0 0 25%;
-webkit-flex: 0 0 25%;
-ms-flex: 0 0 25%;
}
尝试更改%后,您就会明白这一点 这个问题太宽泛,需要征求意见。请将问题缩小到与编程相关的特定问题。这个问题太宽泛,需要征求意见。请将问题缩小到与编程相关的特定问题。