CSS – 实战 Spacing & Layout
前言
这篇想整理一下在网页开发中, Spacing (间距) 和 Layout 排版是如果被处理的.
Spacing 介绍
东西密密麻麻会给人一种很恐怖的感觉. 只要加上一点空间 (间距), 整体感觉立马就会变好很多.
在网页开发中, padding, margin, gap, line-height 是最常用来做间距的. 它们各有特点, 也有重叠的部分, 所以最好有一个 best practice 不要乱用一通.
Padding
padding 是内间距, 用来给 parent child 制造空间.
padding 可以替代 margin (Figma 就没用 margin), 但是 padding 不能被 margin, gap 替代. 所以一般不会用错.
例子1: botton padding

例子 2 : viewport padding, header padding, content padding

绿色的部分都是 padding
Padding + negetive margin

上面这几个 nav link 需要间距. 最合适是用 padding 来实现. 因为要点击嘛. padding 空间会比较大.
gap 和 margin 的区域不属于内容也就无法被点击. 这也是 padding 和 gap, margin 很大的区别.
但有些场景则相反, 比如需要 background-color 的情况下, 用 padding 就不行了, 因为它是内容的一部分也会有 background-color 这样就看不到间距了.
注意: 用 padding 做间距会有 first element 和 last element 额外空间的 feel. 因为 padding 是不会 collapse 的, 所以需要配上 negetive margin 来 "帮" 它 collapse.
这个在管理上会有小扣分.
Margin
padding 是 parent child, margin 是 sibling
margin 的出场率会比 padding 少, 大部分情况还会被 gap 替代, 所以对我来说 margin 是比较冷门的.

中间的 slash 就用了 margin inline.

橙色部分就是 margin-top

橙色部分就是 margin-bottom
margin-top vs margin-bottom
有时候会发现, margin-top, margin-bottom 是可以互换的, 毕竟都是让 2 个 sibling element 分开. 给其中任何一个都是可以达到同一效果的.
但是通常我会使用 margin-top 因为这个是赋予在第 2 个 element 的, 因为有了这第 2 个 element 才会需要空间, 所以职责给它是合理的.
我只会对 title 使用 margin-bottom, 因为 title 通常会配上内容, 而让每一个内容都设置 margin-top 我觉得让 title 设置 margin-bottom 会跟简单直观一些.
总之不要纠结太多, 大部分情况 margin-top 是对的, 如果你觉得有个地方 margin-bottom 更好, 那么就用呗.
margin collapse
当两个 element 的 margin-bottom 遇上 margin-top 时, 它会形成重叠, 比如:
element A 有 margin-bottom 30px
element B 有 margin-top 50px
最终它们的间距时 50px 而不是 80px. (因为 margin 的表达是 A element 要和下面的 element 保持 30px, 而 50px 间距已经达到目的了)
gap

紫色的都是 gap
gap 也是处理 sibling 间距的. 绝大多数的情况下, gap 可以取代 margin.
我也鼓励这样做, 因为它比较直观.
1. 如果是多个 element 要做间距, 而且间距刚好相同, 那么 gap 会很好, (对比 margin 需要搞 n + 2 margin-top)
2. 如果只有 2 个 element 要做间距, 尽可能用 gap, 哪怕需要额外加 Flex, Grid 属性 (如果要加 wrapper element 就不要了)
3. 如果有多个 element 间距不同, 用 margin-top, 也可能配上 gap 一起用.
line-height
line-height 是 paragraph 行的间距.
line-height 一般用的是 percentage. 不同字体默认是不一样的, 通常在 1.2 左右.
也就是说 16px 的字, 高度是 16 x 1.2 = 19.2

2 点要注意:
当 paragraph 有 multiple line 的时候, 1.5 的 line-height 通常会更好一些
当只有 single line heading 1-6 的时候, line-height 1.0 通常会好一些. 因为字越大 line-height 越大.
CSS – 实战 Spacing & Layout的更多相关文章
- 前端开发css实战:使用css制作网页中的多级菜单
前端开发css实战:使用css制作网页中的多级菜单 在日常工作中,大家都会遇到一些显示隐藏类菜单,比如页头导航.二维码显示隐藏.文本提示等等......而这些效果都是可以使用纯css实现的(而且非常简 ...
- DIV+CSS实战(三)
一.说明 在上篇博客<DIV+CSS实战(二)>中,实现了头部以及Tab标签卡,下面开始实现内容区域,要实现的效果如下: 二.内容最外层的设计(边框) 给最外层加边框,并且设置高度随着里面 ...
- DIV+CSS实战(二)
一.说明 在DIV+CSS实战(一)中,已经把框架搭建起来了,现在就需要往框架里面添加内容了.需要实现的内容如下图: 二.头部的设计(全媒体订阅) 左侧是一张图片+标题 ,右侧是登录名 和上次登录的时 ...
- css之Grid Layout详解
css之Grid Layout详解 CSS Grid Layout擅长将页面划分为主要区域,或者在从HTML基元构建的控件的各个部分之间定义大小,位置和图层之间的关系. 与表格一样,网格布局使作者能够 ...
- CSS flex waterfall layout
CSS flex waterfall layout https://github.com/YoneChen/waterfall-flexbox https://css-tricks.com/snipp ...
- css——letter spacing
letter spacing属性是用来设置字母的间距 实例: 设置h1和h2之间字母的间距 <html> <head> <style type="text/cs ...
- CSS实战中经常出现的问题。
如果你把这些当做文章来看,那你始终是学不会,而是应该当做手册来看,这些也是自己在写网站遇到的问题.转载请出处. 追梦子前端博客. 1. logo添加内容给h1设置text-index:-9999px的 ...
- 第一天CSS实战培训及笔记及感想
首先,我很激动...... 3点了,凌晨3点了,我居然还没睡.总共不到3个小时的视频消化了6个小时,今天是培训班第一天,一下子就来高强度的讲课,整个上过基础班的都听得东倒西歪,更别说我这个没上基础班滴 ...
- CSS 权威指南 CSS实战手册 第四版(阅读笔记)
前言: 对于程序员,学习是无止境的,知识淘换非常快,能够快速稳固掌握一门新技术,是一个程序员应该具备的素质.这里将分析本人一点点不成熟的心得. 了解一门语言,了解它的概念非常重要,但是一些优秀的设计思 ...
- css实战——第一天
1. 开发前的准备 1.1配置开发环境 sublime webstorm vscode Hbuilder atom 1.2建立项目文件夹 主页或是首页 index.html d ...
随机推荐
- Java JVM——12. 垃圾回收理论概述
1.前言 1.1 什么是垃圾? 在提到什么是垃圾之前,我们先看下面一张图: 从上图我们可以很明确的知道,Java 和 C++ 语言的区别,就在于垃圾收集技术和内存动态分配上,C++ 语言没有垃圾收集技 ...
- Django模型中的save方法 精讲
两种方法定义在Django模型中的save方法有不同的参数处理方式. 第一种方法: def save(self, *args, **kwargs): super().save(*args, **kwa ...
- vue 路由缓存 keep-alive include和exclude无效
<keep-alive :include="keepAliveData"> <router-view v-if="isShowRouter" ...
- MySQL常用语句(经常容易忘记)
MySQL常用语句 一.连接MySQL 格式: mysql -h <主机地址> -u<用户名> -p<用户密码> --port=<端口号> 1.例1:连 ...
- 【微信小程序】05 设备信息 & 请求API
获取系统信息(设备信息) https://developers.weixin.qq.com/miniprogram/dev/api/base/system/wx.getSystemInfo.html ...
- 【JavaScript】无框架翻页处理
这个业务太复杂了 输入框的东西要用接口查出来,居然不是用户手动输入 然后我就要做一个翻页的查询列表: <div form id="troublePartSearch" sty ...
- 【Lodop】02 C-Lodop手册阅读上手
版本:4.0.6.2 一.概述 C-Lodop云打印是一款精巧快捷的云打印服务产品,以Lodop功能语句为基础,JS语句实现远程打印 移动设备+Wifi+普通打印机+集中打印 C-Lodop对客户端浏 ...
- 如果美国断供中国所有的Intel和AMD芯片,国内各行各业会不会崩溃
说一个我个人观点,我认为如果国内完全没有X86芯片的供应,那么各行各业的发展会明显进入发展迟缓阶段,首先受影响的就是软件开发领域,因为没有新的芯片也就意味着袋电脑性能停滞或者倒退,那么开发出新的更耗资 ...
- 【转载】 PID原理与参数调试
原文地址: http://m.elecfans.com/article/1153309.html --------------------------------------------------- ...
- 在使用pytorch官方给出的torchvision中的预训练模型参数时为保证收敛性要求使用原始的数据预处理方式
本文主要内容如题: 在使用pytorch官方给出的torchvision中的预训练模型参数时为保证收敛性要求使用原始的数据预处理方式 具体的pytorch官方讨论: https://github.co ...