2017-06-05 187 views
0
如圖這裏遇到麻煩的外層div內水平對齊紡絲圓動畫(載帶的「自旋面板」 ID在div內)(的「加載」 ID)

https://codepen.io/depaolif/pen/MoYwrP水平對齊的div

有沒有人知道爲什麼margin: auto在這種情況下不會像通常那樣工作?

HTML:

<div id="loading"> 
    Loading account info 
    <div id="spin-panel"> 
     <span id="loading8-1"> 
      <span id="CircleBottom"><span class="ball"></span></span> 
     </span> 
     <span id="loading8-2"> 
      <span id="CircleMiddle"><span class="ball"></span></span> 
     </span> 
     <span id="loading8-3"> 
      <span id="CircleTop"><span class="ball"></span></span> 
     </span> 
    </div> 
</div> 

SCSS:

@keyframes cwSpin { 
    0%{transform:rotate(0deg);} 
    100%{transform:rotate(360deg);} 
} 

#loading { 
    text-align: center; 
    margin-top: 40vh; 
    font-size: 40px; 
    width: 100vw; 

    #spin-panel { 
    width: 50%; // this doesn't make a difference 
    margin: 0 auto; 

    #loading8-1, #loading8-2, #loading8-3 { 
     display:block; 
     position:absolute; 
     margin:30px 0 0 100px; 
     width:80px; 
     height:80px; 
     animation: cwSpin 1s linear 0s infinite; 


     #CircleBottom, #CircleMiddle, #CircleTop { 
      display:block; 
      position:absolute; 

      width:100px; 
      height:100px; 

      border-radius:100px; 

      .ball { 
      width:20px; 
      height:20px; 
      display:block; 
      position:absolute; 
      background-color:#06C; 
      border-radius:20px; 
      margin:0 0 0 45px; 
      } 
     } 

     #CircleBottom { 
      transform:rotate(0deg); 
     } 
     #CircleMiddle { 
      transform:rotate(50deg); 
     } 
     #CircleTop { 
      transform:rotate(100deg); 
     } 
     } 
    } 
    } 
+0

添加在#旋面板位置:相對; – PlayerWet

+0

您是否已選擇我的答案作爲解決方案?如果是這樣,我很好奇爲什麼? –

回答

2

#spin-panel居中,但孩子們都絕對定位,並有利潤抵消自己的位置。

position: relative加到#spin-panel,並給正在旋轉的孩子添加top: 0; left: 50%; transform: translateX(-50%);並刪除左邊距以水平居中。

@keyframes cwSpin { 
 
    0% { 
 
    transform: translateX(-50%) rotate(0deg); 
 
    } 
 
    100% { 
 
    transform: translateX(-50%) rotate(360deg); 
 
    } 
 
} 
 
#loading { 
 
    text-align: center; 
 
    margin-top: 40vh; 
 
    font-size: 40px; 
 
    width: 100vw; 
 
} 
 
#loading #spin-panel { 
 
    width: 50%; 
 
    margin: 1em auto 0; 
 
    position: relative; 
 
} 
 
#loading #spin-panel #loading8-1, #loading #spin-panel #loading8-2, #loading #spin-panel #loading8-3 { 
 
    display: block; 
 
    position: absolute; 
 
    margin: 0 0 0 0; 
 
    width: 80px; 
 
    height: 80px; 
 
    top: 0; 
 
    left: 50%; 
 
    transform: translateX(-50%); 
 
} 
 
#loading #spin-panel #loading8-1 #CircleBottom, #loading #spin-panel #loading8-1 #CircleMiddle, #loading #spin-panel #loading8-1 #CircleTop, #loading #spin-panel #loading8-2 #CircleBottom, #loading #spin-panel #loading8-2 #CircleMiddle, #loading #spin-panel #loading8-2 #CircleTop, #loading #spin-panel #loading8-3 #CircleBottom, #loading #spin-panel #loading8-3 #CircleMiddle, #loading #spin-panel #loading8-3 #CircleTop { 
 
    display: block; 
 
    position: absolute; 
 
    width: 100px; 
 
    height: 100px; 
 
    border-radius: 100px; 
 
} 
 
#loading #spin-panel #loading8-1 #CircleBottom .ball, #loading #spin-panel #loading8-1 #CircleMiddle .ball, #loading #spin-panel #loading8-1 #CircleTop .ball, #loading #spin-panel #loading8-2 #CircleBottom .ball, #loading #spin-panel #loading8-2 #CircleMiddle .ball, #loading #spin-panel #loading8-2 #CircleTop .ball, #loading #spin-panel #loading8-3 #CircleBottom .ball, #loading #spin-panel #loading8-3 #CircleMiddle .ball, #loading #spin-panel #loading8-3 #CircleTop .ball { 
 
    width: 20px; 
 
    height: 20px; 
 
    display: block; 
 
    position: absolute; 
 
    background-color: #06C; 
 
    border-radius: 20px; 
 
    margin: 0 0 0 45px; 
 
} 
 
#loading #spin-panel #loading8-1 #CircleBottom, #loading #spin-panel #loading8-2 #CircleBottom, #loading #spin-panel #loading8-3 #CircleBottom { 
 
    transform: rotate(0deg); 
 
} 
 
#loading #spin-panel #loading8-1 #CircleMiddle, #loading #spin-panel #loading8-2 #CircleMiddle, #loading #spin-panel #loading8-3 #CircleMiddle { 
 
    transform: rotate(50deg); 
 
} 
 
#loading #spin-panel #loading8-1 #CircleTop, #loading #spin-panel #loading8-2 #CircleTop, #loading #spin-panel #loading8-3 #CircleTop { 
 
    transform: rotate(100deg); 
 
} 
 
#loading #spin-panel #loading8-1, #loading #spin-panel #loading8-2, #loading #spin-panel #loading8-3 { 
 
    animation: cwSpin 1s linear 0s infinite; 
 
}
<div id="loading"> 
 
    Loading account info 
 
    <div id="spin-panel"> 
 
    <span id="loading8-1"> 
 
       <span id="CircleBottom"><span class="ball"></span></span> 
 
    </span> 
 
    <span id="loading8-2"> 
 
       <span id="CircleMiddle"><span class="ball"></span></span> 
 
    </span> 
 
    <span id="loading8-3"> 
 
       <span id="CircleTop"><span class="ball"></span></span> 
 
    </span> 
 
    </div> 
 
</div>