189 8069 5689

css如何实现有边框或无边框宫格-创新互联

本篇文章展示了css实现有边框或无边框宫格的步骤,代码简明扼要容易理解,文章内容步步紧凑,希望大家根据这篇文章可以有所收获。

成都创新互联主要从事成都做网站、网站设计、外贸营销网站建设、网页设计、企业做网站、公司建网站等业务。立足成都服务宁阳,十余年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:13518219792

设计目标

在scss环境下, 通过mixin实现n宫格, 并且可以支持"有无边框"和"每个格是否正方形":

@include grid(3, 3, true); // 3 x 3, 有边框, 且每个格为正方形
@include grid(2, 5, false, false); // 2 x 5, 无边框

最终效果

css如何实现有边框或无边框宫格

"padding百分比"小技巧

先解释一个小技巧, 如何实现正方形, 保证看一遍就会, 结论就是:

padding的值如果是百分比, 那么他是相对"父"元素宽度计算的, 也就是说如果"父"元素宽度是100px, "子"元素设置padding-top:100%,"子"元素的padding-top实际上等于100px, 这样就实现了一个正方形(100 x 100). 为了减少干扰, 我们把"子"元素高度设置为0;

css如何实现有边框或无边框宫格

设计思路(无关你是scss还是less)

  1. 为了方便内部元素水平/垂直居中, 整体我们用flex布局.
  2. 使用正方形占位, 因为用了padding-top:100%, 所以我们就需要再单独用一个div来装内容, 我给他起名"item__content".
  3. 为了让内容的容器div充满方块, 我们给他设置样式:position:absolute;top:0;left:0;right:0;bottom:0;;

因此我们的html是这样的:


   
       
    内容...    
 
专门建立的学习Q-q-u-n ⑦⑧④-⑦⑧③-零①②  分享学习方法和需要注意的小细节,互相交流学习,不停更新最新的教程和学习技巧(从零基础开始到WEB前端项目实战教程,学习工具,全栈开发学习路线以及规划)

代码(scss)

这里做了3件事:

为了不冗余, 我把公共的部分抽离的出来起名".a-grid";
mixin支持4个参数, 分别是$row(行数), $column(列数), $hasBorder(是否有边框), $isSquare(是否保证每个块是正方形).
mixin内部通过计算并结合:nth-child实现"整体无外边框"的效果,

.a-grid {
   display: flex;
   flex-wrap: wrap;
   width: 100%;

   .a-grid__item {
     text-align:center;
     position:relative;
     >.item__content {
       display:flex
       flex-flow: column;
       align-items: center;
       justify-content: center;
     }
   }
}

@mixin grid($row:3, $column:3, $hasBorder:false, $isSquare:true) {
   @extend .a-grid;

   .a-grid__item {

     flex-basis: 100%/$column;

     @if($isSquare) {
       padding-bottom: 100%/$column;
       height: 0;
     }

     >.item__content {

       @if($isSquare) {
         position:absolute;
         top:0;left:0;right:0;bottom:0;
       }
     }
   }

   @for $index from 1 to (($row - 1) * $column + 1) {
     .a-grid__item:nth-child(#{$index}) {
       @if($hasBorder) {
         border-bottom: 1px solid #eee;
       }
     }
   }

   @for $index from 1 to $column {
     .a-grid__item:nth-child(#{$column}n + #{$index}) {
       @if($hasBorder) {
         border-right: 1px solid #eee;
       }
     }
   }
}

使用

// 生成一个 3行3列, 正方形格子的宫格
.a-grid-3-3 {
   @include grid(3, 3, true);
}

// 生成一个 2行5列, 无边框宫格, 每个格子由内容决定高度
.a-grid-2-5 {
   @include grid(2, 5, false, false);
}

提醒大家: 如要做n x m的布局, 用@include grid(n, m)后千万别忘了在html中添加 n x m个对应的dom结构。

关于css实现有边框或无边框宫格的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果喜欢这篇文章,不如把它分享出去让更多的人看到。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


名称栏目:css如何实现有边框或无边框宫格-创新互联
网站网址:http://cdxtjz.cn/article/pdopo.html

其他资讯