2
我正在處理CSS翻轉卡,並遇到此問題,儘管backface-visibility: hidden;
元素仍然可從另一側看到。CSS - 翻轉後在背面可見的元素
如果運行(這裏簡化)片斷,然後點擊more
在右下角 - 卡片翻轉,但more
保持可見。這可能是因爲position: absolute
,因爲其他元素的行爲如預期。
所以我的問題 - 是否有可能解決這個問題(最好只用CSS)並且仍然具有半透明背景?
document.querySelector('.card').addEventListener('click', function(e) {
\t if (e.target.nodeName !== 'I') return;
\t e.target.parentNode.parentNode.classList.toggle('flip');
});
html, body {
height: 100%;
background: linear-gradient(90deg, #9EFFBE 0, #F4FFC7 45%, #F4FFC7 55%, #ADFCFF 100%);
}
.logo {
background: yellow;
border: 8px solid #fff;
border-radius: 50%;
display: block;
height: 120px;
margin: 1em auto;
width: 120px;
}
.item {
border: 1px solid transparent;
display: flex;
height: 170px;
margin: 0 auto .75em;
perspective: 800px;
position: relative;
width: 40%;
}
.card {
width: 100%;
height: 100%;
position: absolute;
transform-style: preserve-3d;
transition: transform 1s;
}
.card figure {
margin: 0;
display: block;
position: absolute;
width: 100%;
height: 100%;
backface-visibility: hidden;
}
.card i {
cursor: pointer;
display: inline-block;
position: absolute;
right: .5em;
bottom: .5em;
}
.card.flip {
transform: rotateY(180deg);
}
.card--front {
background: rgba(255, 255, 255, 0.33);
border: 1px solid #fff;
position: relative;
}
.card--back {
background: #D9FAEF;
background: rgba(255, 255, 255, 0.33);
text-align: center;
position: relative;
transform: rotateY(180deg);
}
<article class="item">
<div class="card">
<figure class="card--front">
<div class="logo"></div>
<i class="icon icon--info-circled">more</i>
</figure>
<figure class="card--back">
<i class="icon icon--cancel-circled">close</i>
</figure>
</div>
</article>
背景實際上是一個梯度(在這裏我把剛纔的簡化片斷),所以這是不行的.. –
@aquaman見我編輯的答案,看看是否適合你。 – Slime
用一個小的調整[作品](http://jsbin.com/luqujipayi/edit?html,css,output)如預期:)謝謝! –