首页前端开发CSS你可能不了解的CSS网格函数!

你可能不了解的CSS网格函数!

时间2024-01-27 22:17:03发布访客分类CSS浏览304
导读:收集整理的这篇文章主要介绍了你可能不了解的CSS网格函数!,觉得挺不错的,现在分享给大家,也给大家做个参考。本篇文章给大家介绍一下CSS中的网格函数:fIT-content( 、minmax( 、rePEat( 。有一定的参考价值,有需要的...
收集整理的这篇文章主要介绍了你可能不了解的CSS网格函数!,觉得挺不错的,现在分享给大家,也给大家做个参考。本篇文章给大家介绍一下CSS中的网格函数:fIT-content()、minmax()、rePEat()。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

这3个函数都只能在网格布局中使用

【推荐教程:CSS视频教程 】

fit-content()

fit-content函数,接收一个参数,长度值,可以按照字面意思来解释他的作用,"适应内容"。

div class="fit-content-wrapper">
      div class="fit-item item1">
    test1dsssss3333333 sssssssssssssss sssssssssssssssssss sssssssssssssssssss ssssssssssssssssssss 这是用了fit-content(400px)/div>
      div class="fit-item item2">
    test2 这是固定宽度width:400px/div>
      div class="fit-item item3">
    test3 这是fit-content(400px)/div>
    /div>
  .fit-content-wrapper{
        width: 100%;
        height: 200px;
        display: grid;
        grid-template-columns: fit-content(400px) 400px fit-content(400px);
        grid-gap: 10px;
  }
  .fit-item{
        background-color: rgb(20, 106, 177);
  }
    

效果

可以看到,当内容长度大于给定长度时,文字会自动换行,不会超过给定长度,当内容长度小于给定长度时,会按照给定的内容长度设置长度。

兼容性

兼容性对于现代浏览器没有什么问题,新版本主流浏览器基本都能支持,对于需要支持ie的项目则不能使用。

minmax()

minmax函数表示一个闭区间范围[min,max],当值小于等于min时,值等于min,当大于等于max时,值等于max.

min-content,max-content

minmax函数接收min-content,max-content参数,这两个参数表示内容最短和最长的内容长度。看下面案例。

    div class="minmax-wrapper">
          div class="minmax-item">
            test1dsssss3333333 sssssssssssssss sssssssssssssssssss        sssssssssssssssssss ssssssssssssssssssss      /div>
          div class="minmax-item">
            p>
    test2222222222/p>
            p>
    test 232232323233/p>
            p>
    min-content采用最短的内容长度/p>
          /div>
          div class="minmax-item">
            p>
    test/p>
            p>
    test 232232323233222222/p>
            p>
    max-content采用最长的内容长度/p>
          /div>
        /div>
      .minmax-wrapper {
            margin-top: 100px;
            width: 100vw;
            display: grid;
            grid-gap: 10px;
            grid-template-columns:          minmax(300px, 500px) minmax(50px, min-content)          minmax(100px, max-content);
      }
    

效果

可以看到,第二个项目的最小的内容宽度为第二个项目中的第一个p标签

当设置成minmax(50px,min-content)时,表示列宽最大的宽度也不能超过第一个p标签的内容宽度。

第三个项目的最大的内容宽度为第三个p标签的内容宽度

当设置成minmax(100px,max-content)时,最大的内容宽度不会超过第三个p标签的宽度

兼容性

跟fit-content函数一样,不支持ie,但对主流的现代浏览器支持还不错。

repeat()

repeat函数用来批量处理网格,接收2个参数,第一个参数表示执行次数,第二个参数表示长度。看下面例子

    div class="repeat-wrapper">
          div class="repeat-item">
    test1 3/div>
          div class="repeat-item">
    test2 23/div>
          div class="repeat-item">
    test3 444/div>
        /div>
      .repeat-wrapper {
            margin-top: 100px;
            display: grid;
            grid-template-columns: repeat(3, 100px);
            grid-gap: 10px;
      }
    

效果

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

auto-fill,auto-fit

第一个参数除了指明具体次数外,repeat还接收这几个参数 auto-fill,auto-fit,下面讲一讲这两个参数的概念。

auto-fill

auto-fill表示由浏览器自动根据项目填充次数。当容器很宽的时候,会自动留出剩余格子的宽度。如果网格容器在相关轴上具有确定的大小或最大大小,则重复次数是最大可能的正整数,不会导致网格溢出其网格容器。

    div class="repeat-wrapper">
          div class="repeat-item">
    test1 3/div>
          div class="repeat-item">
    test2 23/div>
          div class="repeat-item">
    test3 444/div>
          div class="repeat-item">
    test3 4444/div>
          div class="repeat-item">
    test3 444/div>
          div class="repeat-item">
    test3 444/div>
        /div>
    grid-template-columns: repeat(auto-fill, minmax(100px,1fr));
    

效果

auto-fit

auto-fit也会自动计算,但是与auto-fill不同的是,auto-fit不会保留剩余的空格子,会将auto-fill剩余的空格子重新分配到每个格子中。看下面示例

    div class="repeat-wrapper">
          div class="repeat-item">
    test1 3/div>
          div class="repeat-item">
    test2 23/div>
          div class="repeat-item">
    test3 444/div>
          div class="repeat-item">
    test3 4444/div>
          div class="repeat-item">
    test3 444/div>
          div class="repeat-item">
    test3 444/div>
        /div>
    grid-template-columns: repeat(auto-fit, minmax(100px,1fr));
    

效果

兼容性

最新版本的主流浏览器基本都能支持,依旧不支持ie。

总结

这3个网格函数极大的丰富的网格布局,之前用网格布局用的不多,但是今天学习这3个函数以及相关的一些参数后,发现网格布局对比其他布局也是很方便的,后面在一些自己的小项目中可以试着用一下。

更多编程相关知识,请访问:编程视频!!

以上就是你可能不了解的CSS网格函数!的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: css怎么让两个div在同一行显示下一篇:css怎么将鼠标变小手样式猜你在找的CSS相关文章 css怎么控制按钮不可用2022-05-17css3中transform属性实现的4种功能2022-04-13纯CSS3实现div按照顺序出入效果2022-04-13CSS实现隐藏搜索框功能(动画正反向序列)2022-04-13使用CSS3实现按钮悬停闪烁动态特效代码2022-04-13CSS3 Tab动画实例之背景切换动态效果2022-04-13CSS实现两列布局的N种方法2022-04-13CSS 实现Chrome标签栏的技巧2022-04-13css实现两栏布局左侧固定宽右侧自适应的多种方法2022-04-13从QQtabBar看css命名规范BEM的详细介绍2022-04-13 其他相关热搜词更多phpjavapython程序员

若转载请注明出处: 你可能不了解的CSS网格函数!
本文地址: https://pptw.com/jishu/588789.html
纯CSS如何实现图片轮播 css怎么将鼠标变小手样式

游客 回复需填写必要信息