css3 - CSS布局flex问题
问题描述
http://jsfiddle.net/deathfang/6kSNV/1/
上面这种布局,可以用更简洁的HTML实现不?
比如这种
<ul> <li style='background: red'>1</li> <li style='background: green'>2</li> <li style='background: yellow'>3</li> <li style='background: yellowgreen'>4</li> <li style='background: greenyellow'>5</li> <li style='background: pink'>6</li> <li style='background: blueviolet'>7</li> <li style='background: aliceblue'>8</li> <li style='background: orangered'>9</li></ul>
float方案上面也有,iOS7 safari测试右边会有1px误差,手机扫描下面二维码可以看到

问题解答
回答1:当然可以, 既然你那么节约代码, 那么就不用选择使用ul了(还要去除默认样式).实现的关键点在于:
父级flex-wrap高为wrap (默认是nowrap)子元素有border的话, 把box-sizing的值设为border-boxjsfiddle卡出翔了, 直接看代码吧:
HTML:
<p class='flex-container'> <p class='flex-item flex-gold'>1</p> <p class='flex-item flex-red'>2</p> <p class='flex-item flex-pink'>3</p> <p class='flex-item flex-blue'>4</p> <p class='flex-item flex-yellowgreen'>5</p> <p class='flex-item flex-lightgreen'>6</p></p>
CSS:
.flex-container { display: flex; flex-flow: row wrap;}.flex-item { color: #fff; flex: 1 33.33333333%; height: 70px; line-height: 70px; text-align: center; border: solid 1px #efefef; box-sizing: border-box;}.flex-gold { background-color: gold;}.flex-red { background-color: red;}.flex-pink { background-color: pink;}.flex-blue { background-color: blue;}.flex-yellowgreen { background-color: yellowgreen;}.flex-lightgreen { background-color: lightgreen;}回答2:
其实可以的,使用浮动和负边距来做。但是,还需要一个额外的层来控制宽度,这样就可以做到控制显示每行显示多少个item。具体请见:http://www.cnblogs.com/my_front_research/archive/2013/01/09/2853274.html,本文中负边距部分。
相关文章:
1. javascript - sublime什么插件可以在我自动保存代码之后,对es6代码自动检查并格式化。2. javascript - jquery事件绑定中的this指向问题3. mysql - msql什么叫并发4. 求大神帮我看看是哪里写错了 感谢细心解答5. 不解的nginx rewrite规则6. mysql - jdbc的问题7. mysql - JAVA怎么实现一个DAO同时实现查询两个实体类的结果集8. wordpress - Nginx中禁止访问txt,robots.txt文件例外,规则该怎么写?9. ,我写的代码哪里出错了?为什么就是显示不出来peter?10. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题

网公网安备