2017-12-09 2 views
0

これは正しく動作するように多くのアプローチを試みましたが、成功しませんでした..この質問は既に数回質問されています。だから私はあなたの誰かが重複としてこの質問を見つけた場合申し訳ありませんと言う:(CSS:div要素のホバーで〜または+で別のdivをアニメーション化する

ホバー要素は「食べ物で先行ます

..しかし、なし、成功して..私が見つけた解決策を試してみましたVEの「ボックス」、スケールアニメーションを必要とする要素は「フードボックス画像」である。

<div class="food-box"> 
     <div class="food-box-image" style="background-image: url(myimage.jpg);"></div> 

...と私はこのような作業をアニメーション取得しようとしている:

.food-box:hover ~ .foox-box-image { 
     -moz-transform: scale(1.1); 
     -webkit-transform: scale(1.1); 
     transform: scale(1.1); 
    border:8px solid red; 
} 

をそれは発生しません:

私はそれが働いてしまった唯一の方法は、指定しています。食品・ボックス画像..

を置くが、必要なのdiv要素をホバリングするとき、それは発生しませんここで完全なコード(実行されます)です:

誰もがこれを行う方法を知っていますか?

.fixedbuttons-container { 
 
    position: absolute; 
 
    width: 100%; 
 
} 
 

 
.buttons, 
 
.fixedbuttons { 
 
    display: flex; 
 
    flex-flow: row wrap; 
 
} 
 

 
    .fixedbuttons > * { 
 
     width: 25%; 
 
    } 
 

 
     .fixedbuttons > * > * { 
 
      width: 100%; 
 
      text-align: center; 
 
     } 
 
.food-box-container { 
 
    padding: 10px; 
 
} 
 

 
.food-box { 
 
    flex: 1; 
 
    position: relative; 
 
    background-color: white; 
 
    min-height: 300px; 
 
    background-color: #ffffff; 
 
    -webkit-box-shadow: 0px 0px 20px 4px rgba(0, 0, 0, 0.35); 
 
    -moz-box-shadow: 0px 0px 20px 4px rgba(0, 0, 0, 0.35); 
 
    box-shadow: 0px 0px 20px 4px rgba(0, 0, 0, 0.35); 
 
    border-color: #666666; 
 
    border: 1px solid #666666; 
 
    word-wrap: break-word; 
 
    margin: 0 !important; 
 
    padding: 0 !important; 
 
    -moz-transition: all .1s ease-in; 
 
    -o-transition: all .1s ease-in; 
 
    -webkit-transition: all .1s ease-in; 
 
    transition: all .1s ease-in; 
 
} 
 

 
    .food-box:hover { 
 
     cursor: pointer; 
 
     -webkit-box-shadow: 0px 0px 20px 4px rgba(255, 255, 255, 0.35); 
 
     -moz-box-shadow: 0px 0px 20px 4px rgba(255, 255, 255, 0.35); 
 
     box-shadow: 0px 0px 20px 4px rgba(255, 255, 255, 0.35); 
 
     -moz-transition: all .1s ease-in; 
 
     -o-transition: all .1s ease-in; 
 
     -webkit-transition: all .1s ease-in; 
 
     transition: all .1s ease-in; 
 
    } 
 

 
    .food-box:hover ~ .foox-box-image { 
 
      -moz-transform: scale(1.1); 
 
      -webkit-transform: scale(1.1); 
 
      transform: scale(1.1); 
 
     border:8px solid red; 
 
    } 
 

 
    .food-box .food-box-image { 
 
     position: absolute top: 0 left: 0; 
 
     background-size: cover; 
 
     width: 100%; 
 
     min-height: 150px; 
 
     background-color: #ffffff; 
 
     -moz-transition: all 0.3s; 
 
     -webkit-transition: all 0.3s; 
 
     transition: all 0.3s; 
 
    } 
 

 
    .food-box .food-box-content { 
 
     -moz-transition: all .1s ease-in; 
 
     -o-transition: all .1s ease-in; 
 
     -webkit-transition: all .1s ease-in; 
 
     transition: all .1s ease-in; 
 
     position: absolute bottom: 0 left: 0; 
 
     word-wrap: break-word; 
 
     width: 100%; 
 
     min-height: 150px; 
 
     background-color: #ffd531; 
 
     color: #000000; 
 
     font-size: 80%; 
 
     padding-top: 60px; 
 
     padding-left: 5px; 
 
     padding-right: 5px; 
 
    } 
 

 
    .food-box:hover > .food-box .food-box-content { 
 
     background: yellow !important; 
 
     -moz-transition: all .1s ease-in; 
 
     -o-transition: all .1s ease-in; 
 
     -webkit-transition: all .1s ease-in; 
 
     transition: all .1s ease-in; 
 
    } 
 

 
    .food-box .food-box-badge { 
 
     display: table; 
 
     background: #ffffff !important; 
 
     position: absolute; 
 
     left: 50%; 
 
     top: 50%; 
 
     -webkit-transform: translate(-50%, -50%); 
 
     transform: translate(-50%, -50%); 
 
     width: 100px; 
 
     height: 100px; 
 
     line-height: 100px; 
 
     border-radius: 50%; 
 
     font-size: 12px; 
 
     color: #000000; 
 
     text-align: center; 
 
     -webkit-box-shadow: 0px 0px 39px 4px rgba(0, 0, 0, 0.75); 
 
     -moz-box-shadow: 0px 0px 39px 4px rgba(0, 0, 0, 0.75); 
 
     box-shadow: 0px 0px 39px 4px rgba(0, 0, 0, 0.75); 
 
     border-color: #d3e0e9; 
 
     border: 1px solid #b3c9e5; 
 
     padding-left: 10px; 
 
     padding-right: 10px; 
 
    } 
 

 
     .food-box .food-box-badge span { 
 
      color: #666; 
 
      display: table-cell; 
 
      vertical-align: middle; 
 
      line-height: 1.2em; 
 
      word-wrap: break-word; 
 
     }
<div class="fixedbuttons-container"> 
 
    <div class="fixedbuttons"> 
 
    <div> 
 
     <a> 
 
     <div class="food-box-container"> 
 
      <div class="food-box"> 
 
      <div class="food-box-image" style="background-image: url(https://assets.epicurious.com/photos/57c5c6d9cf9e9ad43de2d96e/master/pass/the-ultimate-hamburger.jpg);"></div> 
 
      <div class="food-box-badge"><span>Sydhavsmeny</span></div> 
 
      <div class="food-box-content"> 
 
       adslkfjaølkfj 
 
      </div> 
 
      </div> 
 
     </div> 
 
     </a> 
 
    </div> 
 
    <div> 
 
     <a> 
 
     <div class="food-box-container"> 
 
      <div class="food-box"> 
 
      <div class="food-box-image scalable" style="background-image: url(https://assets.epicurious.com/photos/57c5c6d9cf9e9ad43de2d96e/master/pass/the-ultimate-hamburger.jpg);"></div> 
 
      <div class="food-box-badge"><span>Sydhavsmeny</span></div> 
 
      <div class="food-box-content"> 
 
       adslkfjaølkfj 
 
      </div> 
 
      </div> 
 
     </div> 
 
     </a> 
 
    </div> 
 
    </div </div>

+2

あなたはそこにタイプミス(食品対foox)を持っています。二つ目は、.food-box:hover〜.food-box-image'(子セレクタ、兄弟ではない)の代わりに '.food-box:hover> .fo-box-image'を使う必要があることです。 – panther

+0

@panther:true :)最後にバグがあった...セレクタの更新をありがとう...あなたはbtwを知っていますか?どのように画像のスケーリングが行かないかどうかを確認できます_outside_ boundries親箱の? –

答えて

1

今@panther

で指摘したように最初は、あなたがコンテナボックス内のみスケールにしたい場合はラッピングにoverflow: hiddenを適用.food-box:hover > .foox-box-imageと交換するタイプミスfoox*ですコンテナはfood-box

です。これはあなたが期待しているものです。

.fixedbuttons-container { 
 
    position: absolute; 
 
    width: 100%; 
 
} 
 

 
.buttons, 
 
.fixedbuttons { 
 
    display: flex; 
 
    flex-flow: row wrap; 
 
} 
 

 
    .fixedbuttons > * { 
 
     width: 25%; 
 
    } 
 

 
     .fixedbuttons > * > * { 
 
      width: 100%; 
 
      text-align: center; 
 
     } 
 
.food-box-container { 
 
    padding: 10px; 
 
} 
 

 
.food-box { 
 
    overflow: hidden; 
 
    flex: 1; 
 
    position: relative; 
 
    background-color: white; 
 
    min-height: 300px; 
 
    background-color: #ffffff; 
 
    -webkit-box-shadow: 0px 0px 20px 4px rgba(0, 0, 0, 0.35); 
 
    -moz-box-shadow: 0px 0px 20px 4px rgba(0, 0, 0, 0.35); 
 
    box-shadow: 0px 0px 20px 4px rgba(0, 0, 0, 0.35); 
 
    border-color: #666666; 
 
    border: 1px solid #666666; 
 
    word-wrap: break-word; 
 
    margin: 0 !important; 
 
    padding: 0 !important; 
 
    -moz-transition: all .1s ease-in; 
 
    -o-transition: all .1s ease-in; 
 
    -webkit-transition: all .1s ease-in; 
 
    transition: all .1s ease-in; 
 
} 
 

 
    .food-box:hover { 
 
     cursor: pointer; 
 
     -webkit-box-shadow: 0px 0px 20px 4px rgba(255, 255, 255, 0.35); 
 
     -moz-box-shadow: 0px 0px 20px 4px rgba(255, 255, 255, 0.35); 
 
     box-shadow: 0px 0px 20px 4px rgba(255, 255, 255, 0.35); 
 
     -moz-transition: all .1s ease-in; 
 
     -o-transition: all .1s ease-in; 
 
     -webkit-transition: all .1s ease-in; 
 
     transition: all .1s ease-in; 
 
    } 
 

 
    .food-box:hover > .food-box-image { 
 
      -moz-transform: scale(1.1); 
 
      -webkit-transform: scale(1.1); 
 
      transform: scale(1.1); 
 
    } 
 

 
    .food-box .food-box-image { 
 
     position: absolute top: 0 left: 0; 
 
     background-size: cover; 
 
     width: 100%; 
 
     min-height: 150px; 
 
     background-color: #ffffff; 
 
     -moz-transition: all 0.3s; 
 
     -webkit-transition: all 0.3s; 
 
     transition: all 0.3s; 
 
    } 
 

 
    .food-box .food-box-content { 
 
     -moz-transition: all .1s ease-in; 
 
     -o-transition: all .1s ease-in; 
 
     -webkit-transition: all .1s ease-in; 
 
     transition: all .1s ease-in; 
 
     position: absolute bottom: 0 left: 0; 
 
     word-wrap: break-word; 
 
     width: 100%; 
 
     min-height: 150px; 
 
     background-color: #ffd531; 
 
     color: #000000; 
 
     font-size: 80%; 
 
     padding-top: 60px; 
 
     padding-left: 5px; 
 
     padding-right: 5px; 
 
    } 
 

 
    .food-box:hover > .food-box .food-box-content { 
 
     background: yellow !important; 
 
     -moz-transition: all .1s ease-in; 
 
     -o-transition: all .1s ease-in; 
 
     -webkit-transition: all .1s ease-in; 
 
     transition: all .1s ease-in; 
 
    } 
 

 
    .food-box .food-box-badge { 
 
     display: table; 
 
     background: #ffffff !important; 
 
     position: absolute; 
 
     left: 50%; 
 
     top: 50%; 
 
     -webkit-transform: translate(-50%, -50%); 
 
     transform: translate(-50%, -50%); 
 
     width: 100px; 
 
     height: 100px; 
 
     line-height: 100px; 
 
     border-radius: 50%; 
 
     font-size: 12px; 
 
     color: #000000; 
 
     text-align: center; 
 
     -webkit-box-shadow: 0px 0px 39px 4px rgba(0, 0, 0, 0.75); 
 
     -moz-box-shadow: 0px 0px 39px 4px rgba(0, 0, 0, 0.75); 
 
     box-shadow: 0px 0px 39px 4px rgba(0, 0, 0, 0.75); 
 
     border-color: #d3e0e9; 
 
     border: 1px solid #b3c9e5; 
 
     padding-left: 10px; 
 
     padding-right: 10px; 
 
    } 
 

 
     .food-box .food-box-badge span { 
 
      color: #666; 
 
      display: table-cell; 
 
      vertical-align: middle; 
 
      line-height: 1.2em; 
 
      word-wrap: break-word; 
 
     }
<div class="fixedbuttons-container"> 
 
    <div class="fixedbuttons"> 
 
    <div> 
 
     <a> 
 
     <div class="food-box-container"> 
 
      <div class="food-box"> 
 
      <div class="food-box-image" style="background-image: url(https://assets.epicurious.com/photos/57c5c6d9cf9e9ad43de2d96e/master/pass/the-ultimate-hamburger.jpg);"></div> 
 
      <div class="food-box-badge"><span>Sydhavsmeny</span></div> 
 
      <div class="food-box-content"> 
 
       adslkfjaølkfj 
 
      </div> 
 
      </div> 
 
     </div> 
 
     </a> 
 
    </div> 
 
    <div> 
 
     <a> 
 
     <div class="food-box-container"> 
 
      <div class="food-box"> 
 
      <div class="food-box-image scalable" style="background-image: url(https://assets.epicurious.com/photos/57c5c6d9cf9e9ad43de2d96e/master/pass/the-ultimate-hamburger.jpg);"></div> 
 
      <div class="food-box-badge"><span>Sydhavsmeny</span></div> 
 
      <div class="food-box-content"> 
 
       adslkfjaølkfj 
 
      </div> 
 
      </div> 
 
     </div> 
 
     </a> 
 
    </div> 
 
    </div </div>

+1

ありがとう!..これは_正確に何が探していた! :) –

関連する問題