Html中Grid布局的边框解法

html-css017

Html中Grid布局的边框解法,第1张

众所周知,grid布局目前得到浏览器的支持已经非常可观了,它强大的功能已经成为很多复杂布局的首选。

同时,很多场景里,它也成为了 table 布局的优秀替代方案。

但是很多人在使用grid代替table布局时,却发现了一个严重的问题,那就是:

边框非常不方便!

如图,一般情况下,我们都只能给item设置border,但渲染出来的效果嘛……

效果极其难受,因为每个item都拥有本身的border,这样一来有的地方2px,有的地方1px。

那么应该怎么做呢?

其实很简单,两行css,如下

这样一来,效果就完美了。

需求 :假设高度默认100px ,请写出三栏布局,其中左栏、右栏各为300px,中间自适应

将左右的div宽度设为300px,分别左右浮动,中间盒子不设宽度。注意:先写右边盒子,再写中间盒子,否则先渲染中间盒子,中间盒子会占满该行剩下的宽度,右边盒子只能换行显示,就会出现下面的情况

正常的渲染效果如下所示:

第二种:绝对定位(position:absolute)

设置父盒子position:relative(相对定位),

三个子盒子position:absolute,

左盒子left:0,

右盒子right:0

中间盒子left:300pxright:300px

第三种:flex布局

父盒子 display:flex

左右盒子设置宽度:300px

中间盒子flex:1(flex-grow:1 flex-shrink:1 flex-basis:0%)不考虑元素尺寸自由伸缩

第四种:grid布局

父盒子display: grid

grid-template-columns:300px auto 300px(分割成3列,宽度分别为300px auto 300px)

grid-template-rows:100px(占一行,行高100px)

private function loaderHandler(event:*):void {

switch(event.type) {

case Event.COMPLETE:

trace(_loader.data.result)

break

case Event.OPEN:

trace("open: " + event)

break

case ProgressEvent.PROGRESS:

trace("progress: " + event)

break