2016-05-06 75 views
9

我正在尝试制作卡片翻转并显示其背面。它适用于所有其他浏览器,但不适用于Internet Explorer 11.卡片翻转动画Internet Explorer 11

我试着添加-ms-序言,但没有帮助。问题似乎是IE不支持css属性transform-style: preserve-3d

这里是一个的jsfiddle:https://jsfiddle.net/gbkq94hr/

HTML

<body> 
    <article> 
     <div id="card0" class="card"> 
      <figure class="front"> 
      </figure> 
      <figure class="back"> 
      </figure> 
     </div> 
    </article> 
</body> 

JS

$(document).ready(function() { 
    var flipped = false; 
    var card = $("#card0"); 
    card.click(function() { flipFunction();}); 

    function flipFunction() { 
     if (flipped) { 
      flipped = false; 
      card.removeClass('flip'); 
     } else { 
      card.addClass('flip'); 
      flipped = true; 
     } 
    }; 
}); 

CSS

html { 
    height: 100%; 
} 

.flip { 
    transform: rotateY(180deg); 
} 

.card { 
    float:left; 
    width: 110px; 
    height: 139px; 
    cursor: pointer; 
    transform-style: preserve-3d; 
    transition: transform 1s; 
    position: relative; 
} 

figure { 
    margin: 0; 
    display: block; 
    position: absolute; 
    width: 100%; 
    height: 100%; 
    backface-visibility: hidden; 
    -ms-backface-visibility:hidden; 
} 

.back { 
    background-color: blue; 
    transform: rotateY(-180deg); 
} 

.front { 
    z-index: 2; 
    background-color: red; 
    transform:rotateY(0deg); 
} 

article { 
    height: 114px; 
    width: 114px; 
    perspective: 1000; 
} 

编辑:

正如评论中所建议的那样,我试着遵循David Walshes的指示,但仍然无法使其工作。 https://jsfiddle.net/w9o2chmn/2/

+1

请参阅https://davidwalsh.name/css翻转它可能有帮助 – RRR

+0

这可以工作,但我不能让它在按钮点击工作。 :/ – Waltari

+0

请检查我的回答 – RRR

回答

3

嗨我更改了jQuery代码来执行卡片翻转点击。请检查https://jsfiddle.net/w9o2chmn/6/

HTML 我添加类flip-container到商品标签

<article class="flip-container"> 
    <div id="card0" class="card"> 
     <figure class="front"> 
     front 
     </figure> 
     <figure class="back"> 
     back 
     </figure> 
    </div> 
</article> 

CSS 我在的jQuery删除CSS :hover代码,并把它放在单击

/* entire container, keeps perspective */ 
.flip-container { 
    perspective: 1000; 
    transform-style: preserve-3d; 
    color:#fff; 
} 

/* UPDATED! flip the pane when hovered */ 
    /*.flip-container:hover .back { 
     transform: rotateY(0deg); 
    } 
    .flip-container:hover .front { 
     transform: rotateY(180deg); 
    }*/ 

.flip-container, .front, .back { 
    width: 200px; 
    height: 200px; 
} 

/* flip speed goes here */ 
.card { 
    transition: 0.6s; 
    transform-style: preserve-3d; 

    position: relative; 
} 

/* hide back of pane during swap */ 
.front, .back { 
    backface-visibility: hidden; 
    transition: 0.6s; 
    transform-style: preserve-3d; 

    position: absolute; 
    top: 0; 
    left: 0; 
} 

/* UPDATED! front pane, placed above back */ 
.front { 
    z-index: 2; 
    transform: rotateY(0deg); 
    background:red; 
} 

/* back, initially hidden pane */ 
.back { 
    transform: rotateY(-180deg); 
    background:blue; 
} 

/* 

jQuery

$(document).ready(function() { 
    var flipped=false; 

    $('.flip-container').on('click', function(){ 
     if(!flipped){ 
     $('.back').css('transform','rotateY(0deg)'); 
     $('.front').css('transform','rotateY(180deg)'); 
     flipped=true; 
     console.log('true part :'+flipped); 
     } 
     else{ 
     $('.back').css('transform','rotateY(180deg)'); 
     $('.front').css('transform','rotateY(0deg)'); 
     flipped=false; 
     console.log('else part :'+flipped); 
     } 
    }); 


}); 

请让我知道,如果它为你工作...

PS:我测试了在IE11和工作对我来说

+3

jsFiddle在IE11中不适合我。我在Windows 10上 – nebulousGirl

+0

这非常棒,适用于IE11,Opera,Firefox和Chrome,但在Safari中,动画看起来很奇怪。它看起来像一半是红色,一半是蓝色。任何想法如何解决它? –

+0

在Windows 10上的ie11上不起作用,仅在Windows 8上 –