css语法:学习CSS布局

前端之家收集整理的这篇文章主要介绍了css语法:学习CSS布局前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

布局概念

logo.png&objectId=1330000007013638&token=fda36e996da7d2b1c0438df43fe8d75f" alt="" title="">

#main {
  max-width: 600px;
  margin: 0 auto; 
}

特别注意: padding太大,会把width撑破。(不再受限)

当你设置一个元素为 Box-sizing: border-Box; 时,此元素的内边距和边框不再会增加它的宽度。

.simple {
  width: 500px;
  margin: 20px auto;
  -webkit-Box-sizing: border-Box;
     -moz-Box-sizing: border-Box;
          Box-sizing: border-Box;
}

.fancy {
width: 500px;
margin: 20px auto;
padding: 50px;
border: solid blue 10px;
-webkit-Box-sizing: border-Box;
-moz-Box-sizing: border-Box;
Box-sizing: border-Box;
}

既然没有比这更好的方法,一些CSS开发者想要页面上所有的元素都有如此表现。所以开发者们把以下CSS代码放在他们页面上:

* {
  -webkit-Box-sizing: border-Box;
     -moz-Box-sizing: border-Box;
          Box-sizing: border-Box;
}

“响应式设计(Responsive Design)”是一种让网站针对不同的浏览器和设备“响应”不同显示效果的策略,这样可以让网站在任何情况下显示的很棒!

媒体查询是做此事所需的最强大的工具。让我们使用百分比宽度来布局,然后在浏览器变窄到无法容纳侧边栏中的菜单时,把布局显示成一列:

@media screen and (min-width:600px) {
  nav {
    float: left;
    width: 25%;
  }
  section {
    margin-left: 25%;
  }
}
@media screen and (max-width:599px) {
  nav li {
    display: inline;
  }
}

column

这里有一系列新的CSS属性,可以帮助你很轻松的实现文字的多列布局。让我们瞧瞧:

.three-column {
  padding: 1em;
  -moz-column-count: 3;
  -moz-column-gap: 1em;
  -webkit-column-count: 3;
  -webkit-column-gap: 1em;
  column-count: 3;
  column-gap: 1em;
}

相当于给自己的直系子元素加 inline-block,并紧凑它们,然后提供一些简便的API。(e.g 1/3)

新的 flexBox 布局模式被用来重新定义CSS中的布局方式。很遗憾的是最近规范变动过多,导致各个浏览器对它的实现也有所不同。不过我仍旧想要分享一些例子,来让你知道即将发生的改变。这些例子目前只能在支持 flexBox 的 Chrome 浏览器中运行,基于最新的标准。

网上有不少过时的 flexBox 资料。 如果你想要了解更多有关 flexBox内容,从这里学习如何辨别一份资料是否过时。我已经写了一份关于最新标准的详细文章

使用flexBox你还可以做的更多;这里只是一些让你了解概念的例子:

使用 FlexBox 的简单布局

.container {
  display: -webkit-flex;
  display: flex;
}
nav {
  width: 200px;
}
.flex-column {
  -webkit-flex: 1;
          flex: 1; //所有包含flex配置项的参数和为n,则它占位为1/n,此时就他一个,所以1/1
}

布局案例

margin控制的 是 平凡元素 的真身,但 translate()却相当于给元素赋了 relative 属性,d2真身还在原位置,会对后续元素产生影响。

d3通过margin属性,强行将自己的真身,覆盖在了d2上。这里d2,d3一样大,所以后续元素不受影响,但d2较大,后续元素就会受影响了。

 .d1,.d2,.d3{
             height: 100px;
             width: 100px;
             background-color: #FF0000;
             border: 1px solid #000000;
             box-sizing: border-box;
 }
 .d1 {
         margin: 0 auto;
 }
    .d2{
        margin-left: 50%;
        transform: translate(-100%,0);
        display: inline-block;

}
.d3{
margin-left: -100px;
display: inline-block;
}







你可以用百分比做布局,但是这需要更多的工作。在下面的例子中,当窗口宽度很窄时 nav 的内容会以一种不太友好的方式被包裹起来。总而言之,选一种最合适你的内容的方式。

nav {
  float: left;
  width: 25%;
}
section {
  margin-left: 25%;
}

当布局很窄时, nav 就会被挤扁。更糟糕的是,你不能在 nav 上使用 min-width 来修复这个问题,因为右边的那列是不会遵守它的。

你可以使用 inline-block 来布局。有一些事情需要你牢记:

  • vertical-align 属性会影响到 inline-block 元素,你可能会把它的值设置为 top 。

  • 你需要设置每一列的宽度

  • 如果HTML源代码中元素之间有空格,那么列与列之间会产生空隙

nav {
  display: inline-block;
  vertical-align: top;
  width: 25%;
}
.column {
  display: inline-block;
  vertical-align: top;
  width: 75%;
}

 vertical-align属性 定义行内元素的基线相对于该元素所在行的基线的垂直对齐。

猜你在找的程序笔记相关文章