为什么以下代码在IE10中不起作用?
.foo {
display: -ms-flex;
-ms-justify-content: center;
}
为了让它们起作用,我需要写什么?
答案 0 :(得分:48)
IE10从March 2012实施了Flexbox草案。这些属性对应于:
.foo {
display: -ms-flexbox;
-ms-flex-pack: center;
}
答案 1 :(得分:23)
尝试为所有浏览器提供正确的语法时,一个好的开始是http://the-echoplex.net/flexyboxes/
对于在容器内水平和垂直居中的元素,您将获得如下代码:(在Chrome,FF,Opera 12.1+和IE 10 +中工作)
<强> FIDDLE 强>
<div class="flex-container">
<div class="flex-item">A</div>
<div class="flex-item">B</div>
<div class="flex-item">C</div>
</div>
.flex-container {
height: 100%;
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-box-direction: normal;
-moz-box-direction: normal;
-webkit-box-orient: horizontal;
-moz-box-orient: horizontal;
-webkit-flex-direction: row;
-ms-flex-direction: row;
flex-direction: row;
-webkit-flex-wrap: wrap;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
-webkit-box-pack: center;
-moz-box-pack: center;
-webkit-justify-content: center;
-ms-flex-pack: center;
justify-content: center;
-webkit-align-content: stretch;
-ms-flex-line-pack: stretch;
align-content: stretch;
-webkit-box-align: center;
-moz-box-align: center;
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
}
.flex-item
{
width: 100px;
height:100px;
background: brown;
margin: 0 10px;
}
/*
Legacy Firefox implementation treats all flex containers
as inline-block elements.
*/
@-moz-document url-prefix() {
.flex-container {
width: 100%;
-moz-box-sizing: border-box;
}
}