CSS3中的display:grid,网格布局介绍_css3_CSS_网页制作

来源:脚本之家  责任编辑:小易  

display:none到displayblock是没有过渡效果的,也就是说transform里的函数配合transition都没法用,display:none说是会使浏览器重绘,在display:none到display:block中先执行了transform里的动作,最后才显示display:block的,原因就是W3C渲染就是这样的。希望我理解的正确,有更好解释可以多多指教吧!特殊的:在js中如果个给display:none加个延时 也是可以出现动画效果的www.zgxue.com防采集请勿采集本网。

1.网格布局(grid):

display 属性规定元素应该生成的框的类型,用的最多的就是display:block;显示 display:none;下面是所有值的用法描述。display本身意思是“显示、阵列”的意思 值 描述 none 此元素不会被

        它将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局;

父级元素有display:box;属性之后。他的子元素里面加上box-flex属性。可以让子元素按照父元素的宽度进行一定比例的分占空间。如: html: 01 02 03 article{ width:

2.基本概念

CSS3 弹性盒(Flexible Box 或 flexbox),是一种当页面需要适应不同的屏幕大小以及设备类型时确保元素拥有恰当的行为的布局方式。对于很多应用来讲,弹性盒改进了块模型,既不使用浮动,也不会

        容器和项目,如图所示:

两者的作用是一样的,都是把对象作为弹性伸缩盒来显示(其中box是老版本,flex是新版本)。区别主要在于浏览器的兼容性,下面以常见的IE、FireFox、Chrome来说明: Box: IE所有版本都不支持;

<div class="content"> <div class="b">1</div> <div class="b">2</div> <div class="b">3</div> <div class="b">4</div> <div class="b">5</div> <div class="b">6</div> <div class="b">7</div> <div class="b">8</div> <div class="b">9</div> </div>

CSS中display:block意思如下:如果用<div>+做一个按钮,这个能理解吧,就是 想通过 link 来实现跳转,但是看起来是个按钮,且不需要触发事件。而且 css 也比 button 的好用。这中情况下,如果

        .content即为容器,.b即为项目。

        行和列:        行:row;

        列:column;

3.容器属性

        display:grid;            //默认是块元素;

        display:inline-grid;         //行内块元素

        指定一个容器采用网格布局;

   

        注意:设置为grid后,子元素的float,display: inline-block,display: table-cell、vertical-align和column-*等设置都将失效。

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-columns: 100px 100px 100px; grid-template-rows: 100px 100px 100px; }

4.属性解释

        grid-template-columns:定义每一列的列宽;

        grid-template-columns:100px 100px 100px;      //总共三列,每列列宽是100px;=

        grid-template-rows:定义每一行的行高;

        grid-template-rows:100px 100px 100px;        //从上至下,每行高度为100px;

        //除了使用像素,还可以使用百分比;

        拓展:

            重复写值很麻烦,可以用repeate函数;

            repeat(次数,大小);

            例如:repeat(3,100px);            //重复3次,每次100px;

        repeat写法:

        grid-template-columns:repeat(3,100px);

        grid-template-rows:repeat(3,100px);

        也可以重复某一种不固定大小模式;

        例如:

        grid-template-columns:100px 80px 100px;        

        改写成:

        grid-template-columns:repeat(2,100px 80px);    //代表重复2次100px 80px的模式;也就是4列;

        等同于:

        grid-template-columns:100px 80px 100px 80px;

        如图: 

5.关键字

        1,auto-fill;如果容器大小不固定,项目大小固定,可以用auto-fill关键字自动填充;

        

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-columns: repeat(auto-fill, 100px);}   

 

      

      2,fr(fraction):如果两列的宽度分别为1fr和2fr,就表示后者是前者的两倍。

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-columns: 1fr 2fr; grid-template-rows: repeat(3, 100px 80px);}

   

     

   fr也可以和px配合使用;

 

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-columns: 400px 1fr 2fr;}

     

      

 3.minmax();

      grid-template-columns: 1fr 5fr minmax(100px, 1fr);

      解释:第一列是1fr,第二列是5fr,第三列最小值是100px,最大是1fr。当第二列fr无限大时和第三列到100px时,会往第一列借值;

 

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-columns: 1fr 5fr minmax(100px, 1fr);}

      4.auto:自适应;

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-columns: 100px auto 100px;}

  

6.网格线名称:

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-columns: [c1] 100px [c2] 100px [c3] auto [c4]; grid-template-rows: [r1] 100px [r2] 100px [r3] auto [r4];}

        解释:指定每一根网格线的名字,方便以后的引用。

        也可以有多个名字;[c1,c1a]

7.间距

      row-gap:行间距;

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-columns: 100px 100px 100px; grid-template-rows: 100px 100px 100px; row-gap: 20px;}

    

      colum-gap:列间距; 

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-columns: 100px 100px 100px; grid-template-rows: 100px 100px 100px; column-gap: 20px;}

      

简写:

      gap:20px 20px;

      row-gap和column-gap简写形式;

      gap省略了第二个值,浏览器认为第二个值等于第一个值。

8.区域

  grid-template-areas:网格布局允许指定"区域"(area),一个区域由单个或多个单元格组成。grid-template-areas属性用于定义区域。

.content { box-shadow: 0 0 1px #f6f; display: grid; grid-template-areas: 'a b c' 'd e f' 'g h i'; }

 

总结

以上所述是小编给大家介绍的CSS3中的display:grid,网格布局介绍,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对真格学网网站的支持!如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

display:box;box-flex是css3新添加的盒子模型属性,它的出现可以解决我们通过N多结构、css实现的布局方式。经典的一个布局应用就是布局的垂直等高、水平均分、按比例划分。目前box-flex属性还没有得到firefox、Opera、chrome浏览器的完全支持,但可以使用它们的私有属性定义firefox(-moz-)、opera(-o-)、chrome/safari(-webkit-)内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • js和css3实现带详情页面的炫酷网格布局特效
  • css3中的display:-moz-box是什么意思?是火狐中的什么样式?
  • css3 display none 到 display block 有过渡效果没
  • CSS3 display none 到 display block 有过渡效果没
  • CSS3 display:flex和display:box有什么区别
  • 在CSS样式表中display是什么意思啊。。
  • CSS3 display:flex和display:box有什么区别
  • CSS3 display:flex和display:box有什么区别
  • CSS3 display:flex和display:box有什么区别
  • CSS中display:block是什么意思?
  • CSS3 display:flex和display:box有什么区别
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全主页网页制作csscss3css3display:gridjs和css3实现带详情页面的炫酷网格布局特效css教程css3div+css教程web标准教程浏览器兼容教程css布局实例css3的transform中scale缩放详解纯css绘制漂亮的圆形图案效果纯css实现聊天框小尖角、气泡效果css3通过scale()、rotate()实现放大、旋转css3 icon font完全指南(css3 font 会取代icon图标)css3实现div圆角效果完整代码 css3实现背景颜色渐变让图片不再是唯一的实现方式8款精美的css3表单设计(登录表单/下拉选择/按钮附演示css3 media queries(响应式布局可以让你定制不同的分css3设置box-pack和box-align让div里面的元素垂直居中css3 中filter(滤镜)属性使用详解css3媒体查询中device-width和width的区别详解css3 flex实现div内容水平垂直居中的几种方法浅析css3 中的 transition,transform,translate之间css3 中translate和transition的使用方法css3 不定高宽垂直水平居中的几种方式使用 css3 中@media 实现网页自适应的示例代码css3通过scale()、rotate()实现放大、旋转css3属性 line-clamp控制文本行数的使用用css3实现转换过渡和动画效果
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved