• <center id="sm46c"></center>
  • <dfn id="sm46c"></dfn>
  • <strike id="sm46c"></strike>
  • <cite id="sm46c"><source id="sm46c"></source></cite>
    • <strike id="sm46c"><source id="sm46c"></source></strike>
      <option id="sm46c"></option>
      国产精品天天看天天狠,女高中生强奷系列在线播放,久久无码免费的a毛片大全,国产日韩综合av在线,亚洲国产中文综合专区在,特殊重囗味sm在线观看无码,中文字幕一区二区三区四区在线,无码任你躁久久久久久老妇蜜桃

      彈性布局(Flex)+骰子旋轉(zhuǎn)實例^v^

      2020-3-1    前端達人

      彈性布局(Flex)

      隨著移動互聯(lián)網(wǎng)的發(fā)展,對于網(wǎng)頁布局來說要求越來越高,而傳統(tǒng)的布局方案對于實現(xiàn)特殊布局非常不方便,比如垂直居中。

      2009年,W3C 提出了一種新的方案----Flex 布局,可以簡便、完整、響應式地實現(xiàn)各種頁面布局。目前,它已經(jīng)得到了所有瀏覽器的支持,這意味著,現(xiàn)在就能很安全地使用這項功能。

      下面是一些彈性布局的基本語法:

      兩部分:

      1. 語法是添加到父容器上的
              display : flex;(彈性盒子的標志哦!!!)
              flex-direction: row; 布局的排列方向 (主軸排列方向)
                   row 默認值,顯示為行。方向為當前文檔水平流方向,默認情況下是從左往右。
                   row-reverse  顯示為行。但方向和row屬性值是反的
                   column  顯示為列
                   column-reverse 顯示為列。但方向和column屬性值是反的
              flex-wrap : nowrap; 是否進行換行處理。
                   nowrap; 默認值,不換行處理
                   wrap; 換行處理
                   wrap-reverse; 反向換行
              flex-flow : flex-direction flex-wrap 復合寫法 (是有順序的)。
              justify-content ; 屬性決定了主軸方向上子項的對齊和分布方式。  
                  flex-start : 子項都去起始位置對齊。
                  flex-end : 子項都去結(jié)束位置對齊。
                  center : 子項都去中心位置對齊。
                  space-between : 表現(xiàn)為兩端對齊。多余的空白間距在元素中間區(qū)域分配,兩邊沒寬。 
                  space-around : 邊緣兩側(cè)的空白只有中間空白寬度一半即每個塊都有左右間距。
                  space-evenly :每個flex子項兩側(cè)空白間距完全相等。
              align-items : 每一行中的子元素上下對齊方式。
                  stretch;默認值,flex子項拉伸
                  flex-start;容器頂部對齊
                  center;容器居中對齊
                  flex-end;容器底部對齊
              align-content : 跟justify-content相反的操作。側(cè)軸的對齊方式。(最少需要兩行才能看出效果,因為他是多行的一個上下對齊方式)
                  默認:多行下,有幾行就會把容器劃分為幾部分,默認就是stretch拉伸的。
                  值跟justify-content取值是相同的。
      
      2. 語法是添加到子容器上的?
              order : 排序(值越大越后)
                  0:默認值      eg:1234
                  1:放在后面    eg:1342
                  -2:放在前面   eg:2134
              flex-grow : 擴展 ( 想看到擴展的效果,必須有空隙 )
                  0 : 默認值 , 不去擴展
                  0.5:占空隙的一半
                  1 : 去擴展 , 會把空白區(qū)域全部沾滿
               ( 注:子元素會按照設置的比例值來分配空隙,如果比例值總和小于1,那么會有空隙,如果比例值總和大于等于1,那么就沒有空隙。)
              flex-shrink : 收縮
                  正常默認值是1
                  0表示不收縮,.5收縮小一些,2收縮大一些。(大小是跟正常縮放1進行比較的)
              flex-basis : 跟flex-shrink/flex-grow很像。
                  flex-shrink/flex-grow是設置一個比例值,flex-basis是設置一個具體值。
              flex : 一種復合寫法
                  flex-grow  flex-shrink  flex-basis
                  flex:1;
                      flex : 1 1 0    
                  flex:0;
                      flex : 0 1 0
              algin-self: 跟align-items操作很像,區(qū)別就是只是針對某一個子項。
      
      <!DOCTYPE html>
      <html lang="en">
      <head>
          <meta charset="UTF-8">
          <meta name="viewport" content="width=device-width, initial-scale=1.0">
          <title>Document</title>
          <style>
              *{margin: 0;padding: 0;}
              ul{list-style: none;}
              a{text-decoration: none;}
              img{display: block;}
      
              .box1{width: 150px;height: 150px;display: flex;border: 1px black solid;margin: 20px auto;border-radius: 10px;justify-content: center;align-items: center;}
              .box1 div{width: 30px;height: 30px;border-radius:50%;background: black;}
      
              .box2{width: 150px;height: 150px;display: flex;border: 1px black solid;margin: 20px auto;border-radius: 10px;align-items: center;justify-content: space-between;}
              .box2 div{width: 30px;height: 30px;border-radius:50%;background: black;margin: 10px;}
              .box2 div:nth-of-type(1){align-self: flex-start;}
              .box2 div:nth-of-type(2){align-self: flex-end;}
      
              .box3{width: 150px;height: 150px;display: flex;border: 1px black solid;margin: 20px auto;border-radius: 10px;align-items: center;justify-content: space-between;}
              .box3 div{width: 30px;height: 30px;border-radius:50%;background: black;margin: 10px;}
              .box3 div:nth-of-type(1){align-self: flex-start;}
              .box3 div:nth-of-type(3){align-self: flex-end;}
      
              .box4{width: 150px;height: 150px;border: 1px black solid;margin: 20px auto;border-radius: 10px;display: flex;flex-direction: column;}
              .box4 div{height: 50%;display: flex;flex-direction: row;justify-content: space-around;align-items: center;}
              .box4 div li{display: block; width: 30px;height: 30px;border-radius:50%;background: black;}
      
              .box5{width: 150px;height: 150px;border: 1px black solid;margin: 20px auto;border-radius: 10px;display: flex;flex-direction: column;}
              .box5 div{height: 50%;display: flex;flex-direction: row;justify-content: space-around;align-items: center;}
              .box5 div li{display: block; width: 30px;height: 30px;border-radius:50%;background: black;}
      
              .box6{width: 150px;height: 150px;border: 1px black solid;margin: 20px auto;border-radius: 10px;display: flex;flex-direction: column;}
              .box6 div{height: 50%;display: flex;flex-direction: row;justify-content: space-around;align-items: center;}
              .box6 div li{display: block; width: 30px;height: 30px;border-radius:50%;background: black;}
      
              #box{width: 400px;height: 400px;margin: 20px auto;border: 1px springgreen solid; 
              perspective: 500px;perspective-origin: right top;}
              #box .main{position: relative;width: 150px;height: 150px;margin: 125px;
              transform-style: preserve-3d;transition: 4s;transform-origin: center center -50px;}
              #box .main .box1{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;}
              #box .main .box2{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;left: 150px;transform-origin:left; transform:rotateY(90deg);}
              #box .main .box3{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;left: -150px;transform-origin:right; transform:rotateY(-90deg);}
              #box .main .box4{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;top: -150px;transform-origin:bottom; transform:rotateX(90deg);}
              #box .main .box5{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;top: 150px;transform-origin:top; transform:rotateX(-90deg);}
              #box .main .box6{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;transform:translateZ(-150px) rotateY(180deg);}
      
              #box:hover .main{transform:rotateY(360deg);}
          </style>
      </head>
      <body>
          <div id="box">
              <div class="main">
                  <div class="box1">
                      <div></div>
                  </div>
                  <div class="box2">
                      <div></div>
                      <div></div>
                  </div>
                  <div class="box3">
                      <div></div>
                      <div></div>
                      <div></div>
                  </div>
                  <div class="box4">
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                  </div>
                  <div class="box5">
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                  </div>
                  <div class="box6">
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                  </div>
              </div>
          </div>
      </body>
      </html>
      
      注:默認情況下,在彈性盒子中的子元素的左右排列的。 注: 水平是主軸的時候:默認情況下,當寬高不寫的時候,寬度由內(nèi)容決定,高度由父容器決定。 垂直是主軸的時候:默認情況下,當寬高不寫的時候,寬度由父容器決定,高度由內(nèi)容決定。 注:當子項的總寬度大于父容器的時候,會自動收縮的(彈性的優(yōu)先級是大于自身固定大小的) 注:當子項的內(nèi)容已經(jīng)達到了父容器最小寬高的時候,就會出現(xiàn)溢出的現(xiàn)象。 注:彈性布局中用的頻率比較多的語法: display : flex; flex-direction; justify-content; align-items; flex; 注:彈性布局的優(yōu)勢是做一維布局,網(wǎng)格布局的優(yōu)勢是做二維布局。
      
      
      下面是彈性布局骰子案例代碼:
      
      
      <!DOCTYPE html>
      <html lang="en">
      <head>
          <meta charset="UTF-8">
          <meta name="viewport" content="width=device-width, initial-scale=1.0">
          <title>Document</title>
          <style>
              *{margin: 0;padding: 0;}
              ul{list-style: none;}
              a{text-decoration: none;}
              img{display: block;}
      
              .box1{width: 150px;height: 150px;display: flex;border: 1px black solid;margin: 20px auto;border-radius: 10px;justify-content: center;align-items: center;}
              .box1 div{width: 30px;height: 30px;border-radius:50%;background: black;}
      
              .box2{width: 150px;height: 150px;display: flex;border: 1px black solid;margin: 20px auto;border-radius: 10px;align-items: center;justify-content: space-between;}
              .box2 div{width: 30px;height: 30px;border-radius:50%;background: black;margin: 10px;}
              .box2 div:nth-of-type(1){align-self: flex-start;}
              .box2 div:nth-of-type(2){align-self: flex-end;}
      
              .box3{width: 150px;height: 150px;display: flex;border: 1px black solid;margin: 20px auto;border-radius: 10px;align-items: center;justify-content: space-between;}
              .box3 div{width: 30px;height: 30px;border-radius:50%;background: black;margin: 10px;}
              .box3 div:nth-of-type(1){align-self: flex-start;}
              .box3 div:nth-of-type(3){align-self: flex-end;}
      
              .box4{width: 150px;height: 150px;border: 1px black solid;margin: 20px auto;border-radius: 10px;display: flex;flex-direction: column;}
              .box4 div{height: 50%;display: flex;flex-direction: row;justify-content: space-around;align-items: center;}
              .box4 div li{display: block; width: 30px;height: 30px;border-radius:50%;background: black;}
      
              .box5{width: 150px;height: 150px;border: 1px black solid;margin: 20px auto;border-radius: 10px;display: flex;flex-direction: column;}
              .box5 div{height: 50%;display: flex;flex-direction: row;justify-content: space-around;align-items: center;}
              .box5 div li{display: block; width: 30px;height: 30px;border-radius:50%;background: black;}
      
              .box6{width: 150px;height: 150px;border: 1px black solid;margin: 20px auto;border-radius: 10px;display: flex;flex-direction: column;}
              .box6 div{height: 50%;display: flex;flex-direction: row;justify-content: space-around;align-items: center;}
              .box6 div li{display: block; width: 30px;height: 30px;border-radius:50%;background: black;}
      
              #box{width: 400px;height: 400px;margin: 20px auto;border: 1px springgreen solid; 
              perspective: 500px;perspective-origin: right top;}
              #box .main{position: relative;width: 150px;height: 150px;margin: 125px;
              transform-style: preserve-3d;transition: 4s;transform-origin: center center -50px;}
              #box .main .box1{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;}
              #box .main .box2{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;left: 150px;transform-origin:left; transform:rotateY(90deg);}
              #box .main .box3{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;left: -150px;transform-origin:right; transform:rotateY(-90deg);}
              #box .main .box4{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;top: -150px;transform-origin:bottom; transform:rotateX(90deg);}
              #box .main .box5{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;top: 150px;transform-origin:top; transform:rotateX(-90deg);}
              #box .main .box6{position: absolute;background:limegreen;left: 0;top: 0;
              width: 150px;height: 150px;transform:translateZ(-150px) rotateY(180deg);}
      
              #box:hover .main{transform:rotateY(360deg);}
          </style>
      </head>
      <body>
          <div id="box">
              <div class="main">
                  <div class="box1">
                      <div></div>
                  </div>
                  <div class="box2">
                      <div></div>
                      <div></div>
                  </div>
                  <div class="box3">
                      <div></div>
                      <div></div>
                      <div></div>
                  </div>
                  <div class="box4">
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                  </div>
                  <div class="box5">
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                  </div>
                  <div class="box6">
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                      <div>
                          <li></li>
                          <li></li>
                      </div>
                  </div>
              </div>
          </div>
      </body>
      </html>
      
      
      
      實際效果:
      20200229132935355.png
      
      
      ————————————————
      版權(quán)聲明:本文為CSDN博主「GLINLIND」的原創(chuàng)文章,遵循 CC 4.0 BY-SA 版權(quán)協(xié)議,轉(zhuǎn)載請附上原文出處鏈接及本聲明。
      原文鏈接:https://blog.csdn.net/GLINLIND/article/details/104572530

      
      


      日歷

      鏈接

      個人資料

      藍藍設計的小編 http://www.li-bodun.cn

      存檔

      主站蜘蛛池模板: 国产日韩av一区二区在线| 国产一区二区在线观看的| 久久综合五月婷婷| 久久99精品久久久久久齐齐| 伊人久久大香线蕉亚洲五月天| 亚洲国产精品一区二区制服| 中文字幕久久久人妻无码| 欧美激情乱人伦| 国产亚洲精品VA片在线播放| 亚无码乱人伦一区二区| 亚洲精品综合网二三区| 欧美成人精品手机在线| 亚洲成av不卡无码无码不卡| 免费无码黄十八禁网站| 乱公和我做爽死我视频| 99精品福利视频| 精品久久久久久蜜臂a∨| 欧美一区二区三区国产精品| 国产精品中文第一字幕| 正在播放肥臀熟妇在线视频| 久久久久人妻精品区一三寸| 香蕉在线 亚洲 欧美 专区| 国内精品久久久久影院蜜芽| 熟女激情乱亚洲国产一区| 国产美女精品视频线免费播放软件| 久久99久久99小草精品免视看| 亚洲av午夜成人片| 热九九精品| 精品久久久久久无码免费| 天堂亚洲免费视频| 9久久伊人精品综合| 国产高清成人免费视频在线观看 | 免费无码又爽又刺激动态图| 欧美色图久久| 亚洲AⅤ天堂AV天堂无码| 怀来县| 国内免费视频成人精品| 精品无码久久久久久久久粉色| 亚洲水蜜桃久久综合网站| av秘 无码一区二区三区| 国产精品福利一区二区|