Blogger Information
Blog 27
fans 0
comment 0
visits 19129
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
定位与定位演示/flex布局必会的容器与项目属性
茂林
Original
832 people have browsed it
  1. 实例演示绝对定位与固定定位,并描述联系与区别 2. 实例演示flex必会的容器与项目属性

元素定位

一、定位position

1 定位术语

  1. 定位元素:position: relative,absolute,fixed
  2. 最初包含块:包含了<html>的不可见的,但可感知的区块,类似“视口”;
  3. 参照物:自身;祖先定位元素;最初包含块;

    2 坐标系

    1- 起始点: 左上角,坐标[x,y]=>[0,0]
    2- 变化方向: 向右x变大, 向下y变大
    3- 页面四个顶点用: top,left,right,bottom 表示

    3 定位元素

    1- 定位元素: 也叫”可定位元素”,允许用户自定义元素的位置与排列方式
    2- 判断依据: position: relative | absolute | fixed

    4 定位类型

    1-. 静态: position: static, 文档流中的元素的默认定位方式
    2-. 相对: position: relative, 相对原始位置偏移,仍在文档流中
    3-. 绝对: position: absolute, 相对距离最近的定位元素发生偏移
    4-. 固定: position: fixed, 总相对于最初包含块(html)偏移
    5-. 粘性: position:sticky:staticfixed,自动切换,元素自动悬停

    5 绝对定位与固定定位的区别与联系

    1.绝对定位时,宽度自动收缩到内容的宽度,释放所占空间,后面顶上去,但是还在父容器中;
    2.绝对定位的元素不再存在于正常文档布局流中;
    3.固定定位的工作方式与绝对定位的工作方式完全相同,只有一个区别,绝对定位将元素固定在相对于其位置最近的一个祖先,如果没有则为初始包含他的块,而固定定位固定元素是相对于浏览器视口本身;
    4.固定定位一般用于,持久的导航栏,广告栏,页面聊天栏等。

各种定位演示

相对定位position:relative和绝对定位position:absolute的演示

  1. <style>
  2. /*整体初始化*/
  3. * {
  4. margin: 0px;
  5. padding: 0px;
  6. box-sizing: border-box;
  7. }
  8. ul {
  9. width: 200px;
  10. height: 100px;
  11. border: 5px solid blue;
  12. }
  13. ul li {
  14. border: 5px solid red;
  15. list-style: none;
  16. }
  17. ul li:first-child {
  18. top: 10px;
  19. left: 10px;
  20. }
  21. ul li:last-child {
  22. border: 5px solid lightblue;
  23. }
  24. /* 相对定位*/
  25. ul li.item1 {
  26. /*转为定位元素*/
  27. position: relative;
  28. /*
  29. relative:将第一个li转成相对定位元素后,item2没有向上偏移,说明item1还在文档流中,所占的空间没有释放。
  30. */
  31. }
  32. </style>
  33. <ul>
  34. <li class='item1'>item1</li>
  35. <li>item2</li>
  36. </ul>
  37. </body>

静态定位(默认)
静态定位
相对定位
相对定位

  1. <body>
  2. <style>
  3. /*整体初始化*/
  4. * {
  5. margin: 0px;
  6. padding: 0px;
  7. box-sizing: border-box;
  8. }
  9. body {
  10. border: 5px solid red;
  11. }
  12. ul {
  13. width: 400px;
  14. height: 400px;
  15. border: 5px solid blue;
  16. }
  17. ul li{
  18. height: 30px;
  19. border: 1px solid #000;
  20. list-style: none;
  21. }
  22. ul li:first-child {
  23. background-color: red;
  24. }
  25. ul li:first-child+* {
  26. background-color: yellow;
  27. }
  28. /* 相对定位*/
  29. ul li.item1 {
  30. /*转为定位元素*/
  31. position: relative;
  32. /*
  33. relative:将第一个li转成相对定位元素后,item2没有向上偏移,说明item1还在文档流中,所占的空间没有释放。
  34. */
  35. top: 10px;
  36. left: 10px;
  37. }
  38. /*绝对定位*/
  39. ul li.item2{
  40. position: absolute;
  41. /*宽度自动收缩到内容的宽度,释放所占空间,后面顶上去,但是还在父容器中*/
  42. /*原始top:40px
  43. item1.height(28+2)+ul.border(5)+body.border(5)=40px
  44. 原始left:10px;
  45. ul.border(5)+body.border(5)=10px
  46. */
  47. top: 100px;
  48. left:100px;
  49. width: auto;
  50. height: auto;
  51. right:200px;
  52. bottom: 50px;
  53. }
  54. /*宽度受限,高度受内容伸展的空间进行布局
  55. 水平居中非常容易,但垂直居中极困难
  56. */
  57. /* li 定位元素 */
  58. /* li ul 不是定位元素 */
  59. /* li ul body 非定位 */
  60. /* html 非定位 */
  61. /* 所有祖先都不是可定位元素,没有参考物了,就得找一个默认的,视口或html */
  62. ul{
  63. /*将li的包容器,转为定位元素*/
  64. position: relative;
  65. }
  66. </style>
  67. <ul>
  68. <li class='item1'>item1</li>
  69. <li class='item2'>item2</li>
  70. </ul>
  71. </body>

固定定位 与 粘性定位

  1. <style>
  2. /*页面初始化*/
  3. * {
  4. margin: 0px;
  5. padding: 0px;
  6. box-sizing: border-box;
  7. }
  8. body {
  9. min-height: 2000px;
  10. }
  11. .box {
  12. width: 150px;
  13. height: 50px;
  14. background-color: lightblue;
  15. /*将box转成固定定位元素,默认的位置是左上起始位置*/
  16. position: fixed;
  17. /*右上*/
  18. /* right: 0px;
  19. top: 0px; */
  20. /* 左下 */
  21. /* left: 0px;
  22. bottom: 0px; */
  23. /* 右下 */
  24. right: 0px;
  25. bottom: 0px;
  26. }
  27. </style>
  28. <body>
  29. <div class="box">固定定位:广告位或客服聊天等用途</div>
  30. </body>


粘性定位

  1. <style>
  2. article figure figcaption{
  3. background-color:lightblue;
  4. color:color;
  5. border:1px solid #000;
  6. padding:1em;
  7. font-size: 1.3em;
  8. /*粘性定位*/
  9. position:sticky;
  10. /*当标题滚动到时自动*/
  11. top:0px;
  12. }
  13. </style>
  14. </head>
  15. <body>
  16. <article>
  17. <figure>
  18. <figcaption>position: sticky </figcaption>
  19. <p>
  20. 还有一个可用的位置值称为 position:
  21. sticky,比起其他位置值要新一些。它基本上是相对位置和固定位置的混合体,它允许被定位的元素表现得像相对定位一样,直到它滚动到某个阈值点(例如,从视口顶部起10像素)为止,此后它就变得固定了。例如,它可用于使导航栏随页面滚动直到特定点,然后粘贴在页面顶部。
  22. </p>
  23. <figcaption>定位上下文 </figcaption>
  24. <p>
  25. 哪个元素是绝对定位元素的“包含元素“?这取决于绝对定位元素的父元素的 position 属性。(参见 Identifying the containing block).
  26. 如果所有的父元素都没有显式地定义 position 属性,那么所有的父元素默认情况下 position 属性都是 static。结果,绝对定位元素会被包含在初始块容器中。这个初始块容器有着和浏览器视口一样的尺寸,并且<html>元素也被包含在这个容器里面。简单来说,绝对定位元素会被放在<html>元素的外面,并且根据浏览器视口来定位。
  27. 绝对定位元素在 HTML 源代码中,是被放在<body>中的,但是在最终的布局里面,它离页面 (而不是<body>) 的左边界、上边界有 30px 的距离。我们可以改变定位上下文 —— 绝对定位的元素的相对位置元素。通过设置其中一个父元素的定位属性 —— 也就是包含绝对定位元素的那个元素(如果要设置绝对定位元素的相对元素,那么这个元素一定要包含绝对定位元素)。为了演示这一点,将以下声明添加到你的 body 规则中:
  28. </p>
  29. </figure>
  30. </article>

二 flex 布局

flex 布局简介

1.flex:弹性盒布局
2.一维布局:每次只能在水平或垂直一个方向布局

flex 术语

1.容器:display:flex / inline-flex
2.项目:flex 容器的子元素(仅限子元素,可嵌套)
3.主轴:项目排列参考线
4.交叉轴:与主轴垂直的参考线

容器属性

1.display:容器类型(块或行内) flex
2.flex-flow:主轴方向与是否换行。
3.place-content:项目在“主轴”上的排列方式;
4.place-items:项目在“交叉轴”上的排列方式;

项目属性

1.flex:项目在“主轴”上的缩放比例与宽度;
2.place-self:某项目在“交叉轴”上的排列方式;
3.order:项目在“主轴”上的排列方式;

flex布局容器和项目属性演示

1. 简写属性flex-flow: flex-direction 和 flex-wrap 组合为简写属性 flex-flow。

  1. 第一个指定的值为 flex-direction,更改 flex 元素的排列方向,`row` 横排/`column` 竖排
  2. 第二个指定的值为 flex-wrap,项目太大而无法全部显示在一行中,则会换行显示, `wrap` 换行/`nowrap` 不换行
  1. <div class="container">
  2. <div>One</div>
  3. <div>Two</div>
  4. <div>Three</div>
  5. <div>One</div>
  6. <div>Two</div>
  7. <div>Three</div>
  8. <div>One</div>
  9. <div>Two</div>
  10. <div>Three</div>
  11. </div>
  12. </body>
  13. <style>
  14. .container {
  15. width: 300px;
  16. height: 150px;
  17. display: flex;
  18. flex-flow: row wrap;
  19. }
  20. .container > div {
  21. border: 1px solid lightblue;
  22. background-color: beige;
  23. }
  24. </style>

结果如下

### # 2.place-content: 项目在主轴上的排列方式

  1. place-content: star; 从头部排列 —主轴项目整体排列
  2. place-content:end;从尾部排列 —主轴项目整体排列
  3. place-content: space-between;—主轴项目独立排列—两端对齐
  4. place-content: space-around;—主轴项目独立排列—分散对齐
  5. place-content: space-evenly;—主轴项目独立排列—平均对齐

place-content: star; 从头部排列

  1. <body>
  2. <div class="container">
  3. <div>O n e</div>
  4. <div>T w o</div>
  5. <div>Three</div>
  6. <!-- <div>F our</div> -->
  7. </div>
  8. </body>
  9. <style>
  10. .container {
  11. width: 300px;
  12. /* height: 50px; */
  13. display: flex;
  14. flex-flow: row wrap;
  15. /* `place-content: star;` 从头部排列 */
  16. place-content: start;
  17. }
  18. .container > div {
  19. border: 1px solid lightblue;
  20. background-color: beige;
  21. height: 50px;
  22. }
  23. </style>

结果
从开始对齐

place-content:end;从尾部排列

  1. <body>
  2. <div class="container">
  3. <div>O n e</div>
  4. <div>T w o</div>
  5. <div>Three</div>
  6. <!-- <div>F our</div> -->
  7. </div>
  8. </body>
  9. <style>
  10. .container {
  11. width: 300px;
  12. /* height: 50px; */
  13. display: flex;
  14. flex-flow: row wrap;
  15. /* `place-content:end; `从尾部排列 */
  16. place-content: end;
  17. }
  18. .container > div {
  19. border: 1px solid lightblue;
  20. background-color: beige;
  21. height: 50px;
  22. }

结果
尾部对齐
place-content: space-between;两端对齐

  1. <body>
  2. <div class="container">
  3. <div>O n e</div>
  4. <div>T w o</div>
  5. <div>Three</div>
  6. <!-- <div>F our</div> -->
  7. </div>
  8. </body>
  9. <style>
  10. .container {
  11. width: 300px;
  12. /* height: 50px; */
  13. display: flex;
  14. flex-flow: row wrap;
  15. /* `place-content: space-between;`两端对齐 */
  16. place-content: space-between;
  17. }
  18. .container > div {
  19. border: 1px solid lightblue;
  20. background-color: beige;
  21. height: 50px;
  22. }
  23. </style>

结果
两端对齐排列

place-content: space-around;分散对齐

  1. <body>
  2. <div class="container">
  3. <div>O n e</div>
  4. <div>T w o</div>
  5. <div>Three</div>
  6. <!-- <div>F our</div> -->
  7. </div>
  8. </body>
  9. <style>
  10. .container {
  11. width: 300px;
  12. /* height: 50px; */
  13. display: flex;
  14. flex-flow: row wrap;
  15. /* `place-content: space-around;`分散对齐 */
  16. place-content: space-around;
  17. }
  18. .container > div {
  19. border: 1px solid lightblue;
  20. background-color: beige;
  21. height: 50px;
  22. }
  23. </style>

结果
分散对齐

place-content: space-evenly;平均对齐

  1. <body>
  2. <div class="container">
  3. <div>O n e</div>
  4. <div>T w o</div>
  5. <div>Three</div>
  6. <!-- <div>F our</div> -->
  7. </div>
  8. </body>
  9. <style>
  10. .container {
  11. width: 300px;
  12. /* height: 50px; */
  13. display: flex;
  14. flex-flow: row wrap;
  15. /* `place-content: space-evenly;`平均对齐 */
  16. place-content: space-evenly;
  17. }
  18. .container > div {
  19. border: 1px solid lightblue;
  20. background-color: beige;
  21. height: 50px;
  22. }
  23. </style>

结果
平均对齐

3.place-items:项目在“交叉轴”上的排列方式

place-items: start; 从开始对齐 与place-items:stretch:默认方式 相同

  1. <style>
  2. .container {
  3. width: 300px;
  4. height: 150px;
  5. display: flex;
  6. flex-flow: row wrap;
  7. /* place-content: space-evenly;*/
  8. place-items: start;
  9. }
  10. .container > div {
  11. border: 1px solid lightblue;
  12. background-color: beige;
  13. height: 30px;
  14. }
  15. </style>

结果

place-items: center; 居中对齐

  1. <body>
  2. <div class="container">
  3. <div>O n e</div>
  4. <div>T w o</div>
  5. <div>Three</div>
  6. <!-- <div>F our</div> -->
  7. </div>
  8. </body>
  9. <style>
  10. .container {
  11. width: 300px;
  12. height: 150px;
  13. display: flex;
  14. flex-flow: row wrap;
  15. /* place-content: space-evenly;*/
  16. place-items: center;
  17. }
  18. .container > div {
  19. border: 1px solid lightblue;
  20. background-color: beige;
  21. height: 30px;
  22. }
  23. </style>

place-items: end; 底部对齐

  1. <body>
  2. <div class="container">
  3. <div>O n e</div>
  4. <div>T w o</div>
  5. <div>Three</div>
  6. <!-- <div>F our</div> -->
  7. </div>
  8. </body>
  9. <style>
  10. .container {
  11. width: 300px;
  12. height: 150px;
  13. display: flex;
  14. flex-flow: row wrap;
  15. /* place-content: space-evenly;*/
  16. place-items: end;
  17. }
  18. .container > div {
  19. border: 1px solid lightblue;
  20. background-color: beige;
  21. height: 30px;
  22. }
  23. </style>

结果

项目属性演示

1. flex: 放大比例 允许收缩 主轴空间
默认,不放大,但可以自动收缩

Correcting teacher:PHPzPHPz

Correction status:qualified

Teacher's comments:
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post