css栅格系统在项目中的灵活运用

news/2023/12/9 16:42:22

前言

css栅格通常捆绑在各种框架中,但有时你需要自己去定制一个css栅格来满足实际的业务需要,本文聊聊css栅格系统在项目中的灵活运用。

需求

UI设计了如下布局,其中左上角橙色部分是固定的,蓝色部分是动态渲染的,从前往后依次展示,有一个就显示一块,有二个就显示二块,依次类推。如果数据多于6个,那么多余的数据,依次再在下方四列的地方进行展示。
图片描述

分析

从图中可以看到,栅格分两种,一种是3列的栅格,一种是4列的栅格。当后端接口返回数据后,js需要进行判断:当数据大于6个时,前6个放在数组A中,数组A中的数据展示在3列的栅格中,多余部分放在数组B中,数组B中的数据展示在4列的栅格中。

html部分

<div id="app">
  <div class="grid-container">
    <div style="width: 25%; height: 220px; float: left; background-color: #FF6600; "></div>
    <div class="row" style="width: 75%; float: right;">
      <div class="col-3" v-for="(item, index) in groupListCol3" :key="index">
        <div class="groups-cell">{{item.name}}</div>
      </div>
    </div>
    <div class="row" style="width: 100%;">
      <div class="col-4" v-for="(item, index) in groupListCol4" :key="index">
        <div class="groups-cell">{{item.name}}</div>
      </div>
    </div>
  </div>
</div>

css部分

    .grid-container {
      width: 100%;
    }
    .grid-container *{
      box-sizing: border-box;
    }

    .grid-container .row:before,
    .grid-container .row:after {
      content: "";
      display: table;
      clear: both;
    }

    .grid-container [class*='col-'] {
      float: left;
      min-height: 1px;
      /*-- gutter --*/
      padding: 0 0 20px 20px;
    }
    .grid-container .col-3{
      width: 33.33%;
      height: 120px;
    }
    .grid-container .groups-cell {
      background-color: #66d3ff;
      height: 100px;
    }
    .grid-container .col-4 {
      width: 25%;
      height: 120px;
    }
    .grid-container .col-4:nth-child(4n+1) {
      padding: 0 0px 20px 0px;
    }

注意:在4列的栅格中,每行的第一个单元格不需要padding-left,所以,最后,还得设置.col-4:nth-child(4n+1)的值。

js部分

<script src="https://cdn.bootcss.com/vue/2.5.16/vue.js"></script>
<script>
  new Vue({
    el: '#app',
    data: {
      groupListCol3: [],
      groupListCol4: []
    },
    created () {
      let list = [
        {name: 'A'},
        {name: 'B'},
        {name: 'C'},
        {name: 'D'},
        {name: 'E'},
        {name: 'F'},
        {name: 'G'},
        {name: 'H'},
        {name: 'I'},
        {name: 'J'},
        {name: 'K'},
        {name: 'L'}
      ]
      if (list.length > 6) {
        this.groupListCol3 = list.slice(0, 6)
        this.groupListCol4 = list.slice(6)
      } else {
        this.groupListCol3 = list
      }
    }
  })
</script>

小结

本文并没有对css栅格的原理进行说明,而是针对具体业务问题,说明如何用css栅格系统来提供解决问题的一种方案,对于栅格系统原理,请见参考部分,这个老外写得非常详细。

参考

Creating Your Own CSS Grid System


http://www.niftyadmin.cn/n/2103758.html

相关文章

ssh整合jar(struts2+spring3+hibernate3)

2019独角兽企业重金招聘Python工程师标准>>> Struts2 的 jar包导入 &#xff08;共14&#xff09; Struts2/apps/struts2-blank.war/*.jar 最基本jar包 &#xff08;13个&#xff09; Struts2/lib/struts2-spring-plugin-2.3.15.3.jar 整合spring &#xff08;1个&…

linux中用户、组、权限的简述

一、用户和组的简单介绍在linux 中每个用户必须属于一个组&#xff0c;而Linux下有三种组的概念&#xff0c;如下&#xff1a; owner &#xff08;文件所属人&#xff09; group &#xff08;用户所在组&#xff09; other &#xff08;其他组&#xff09; 文件…

servlet下根据相对路径找资源

1.在web项目中如果直接添加一个资源&#xff0c;那么相对路径相对的是tomcat的bin目录。  2.在包中直接指定资源&#xff0c;那么可以使用以下的相对路径直接获取资源&#xff1a; InputStream in this.getClass().getResourceAsStream("jnb.txt"); 3.在web项目的w…

rsync,inotify

一、rsync的优点与不足 与传统的cp、tar备份方式相比&#xff0c;rsync具有安全性高、备份迅速、支持增量备份等优点&#xff0c;通过rsync可以解决对实时性要求不高的数据备份需求&#xff0c;例如定期的备份文件服务器数据到远端服务器&#xff0c;对本地磁盘定期做数据镜像等…

Shippable和Packet合作提供原生ARM CI/CD

DevOps自动化平台Shippable和裸金属云服务提供商Packet联合发布了一种新的持续集成和交付&#xff08;CI/CD&#xff09;托管服务&#xff0c;适用于在Armv8-A架构上开发软件应用的开发人员。该解决方案支持开源和商业软件项目&#xff0c;用于在Packet提供的基于ARM的云服务上…

mybatis显示sql语句 log4j.properties配置文件

log4j.properties配置如下&#xff1a; 1 将ibatis log4j运行级别调到DEBUG可以在控制台打印出ibatis运行的sql语句,方便调试: 2 3 ### 设置Logger输出级别和输出目的地 ###4 log4j.rootLoggerdebug,stdout,logfile5 6 7 ### 把日志信息输出到控制台 ###8 log4j.appender.stdou…

【RS】Matrix Factorization Techniques for Recommender Systems - 推荐系统的矩阵分解技术

【论文标题】Matrix Factorization Techniques for Recommender Systems&#xff08;2009&#xff0c;Published by the IEEE Computer Society&#xff09; 【论文作者】Yehuda Koren&#xff08;Yahoo Research&#xff09; , Robert Bell and Chris Volinsky&#xff08; AT…

常用搜索引擎指令

1. site 用途&#xff1a;用作查询收录情况。 用法&#xff1a;site:www.baidu.com 2. intitle 用途&#xff1a;标题中包含特定关键词的页面 用法&#xff1a;intitle:SEO 3. inurl 用途&#xff1a;url中包含特定关键词的页面 用法&#xff1a;inurl:seo 4. filetype 用途&am…

codec engine工程中使用ccs下编译的lib库

原文地址&#xff1a;codec engine工程中使用ccs下编译的lib库--转作者&#xff1a;木子小白这两天将dsp的算法程序放到ccs下&#xff0c;生成lib库文件 这样的好处就是&#xff1a; 1. 算法封装成lib库以后&#xff0c;看不到源码&#xff0c;保证了代码的安全性&#xff1b; …

win8 查看服务项目

为什么80%的码农都做不了架构师&#xff1f;>>> 按"winR"组合键&#xff0c;打开“运行”窗口&#xff0c;在框中输入“services.msc”回车 转载于:https://my.oschina.net/arrom/blog/267584

笔记本电脑内存升级经历

起因我笔记本内存原本2G,想升级加一条4G或8G.在考虑4G和8G性价比后&#xff0c;决定在京东购买一条kingston ddr3 1333 4G内存。下单后的第二天就送来了&#xff0c;拿着内存兴高采烈的对笔记本开膛破肚后&#xff0c;把内存安装上去。高兴能点亮&#xff0c;进BIOS看到内存显示…

PHP Apache Access Log 分析工具 拆分字段成CSV文件并插入Mysql数据库分析

现在需要分析访问日志&#xff0c;怎么办&#xff1f; 比如分析D:\Servers\Apache2.2\logs\access2014-05-22.log http://my.oschina.net/cart/针对这个问题特意开发了一款小工具分析Apache 日志&#xff0c;拆分字段成CSV文件并插入Mysql数据库分析 <?php $date 2014-05-…

SpringBoot(二)自动配置

使用starter简化依赖配置 Spring提供了一系列starter来简化Maven配置。其核心原理也就是Maven和Gradle的依赖传递方案。当我们在我们的pom文件中增加对某个starter的依赖时&#xff0c;该starter的依赖也会自动的传递性被依赖进来。而且&#xff0c;很多starter也依赖了其他的s…

Entity Framework只entity与DbContext的分离

为什么80%的码农都做不了架构师&#xff1f;>>> 说明&#xff1a;以下例子采用的是DB first的模式 在之前的webform开发模式中我们习惯性性的会建立这样的一些类库&#xff1a;Model、DAL、BLL。。。但是在用了EF以后&#xff0c;我们创建的ADO.NET实体数据模型会默…

第七章-出售未来:及时享乐的经济学

第七章-出售未来&#xff1a;及时享乐的经济学 核心思想: 我们无法明确地预知未来&#xff0c;这为我们带来了诱或让我们拖延着不做某些事。 深入剖析: 你给未来的奖励打了几折?在你的意志力挑战中&#xff0c;每当你屈服于诱惑或拖延的时候&#xff0c;你会出售哪些未来的奖励…

python学习---模块(三)

2019独角兽企业重金招聘Python工程师标准>>> 简介 在前面两节中我们已经学会了函数&#xff0c;以及基本的数据结构。这里由于流程控制&#xff0c;运算符表达式都和其他语言基本都是一样的&#xff0c;所以能够很快理解。上一节&#xff0c;已经学会了如何重用代码…
最新文章