【CSS in Depth 2 精译_027】4.4 Flexbox 元素对齐、间距等细节处理(下)+ 4.5 本章小结

news2025/1/8 17:01:04

当前内容所在位置(可进入专栏查看其他译好的章节内容)

  • 第一章 层叠、优先级与继承(已完结)
    • 1.1 层叠
    • 1.2 继承
    • 1.3 特殊值
    • 1.4 简写属性
    • 1.5 CSS 渐进式增强技术
    • 1.6 本章小结
  • 第二章 相对单位(已完结)
    • 2.1 相对单位的威力
    • 2.2 em 与 rem
    • 2.3 告别像素思维
    • 2.4 视口的相对单位
    • 2.5 无单位的数值与行高
    • 2.6 自定义属性
    • 2.7 本章小结
  • 第三章 文档流与盒模型(已完结)
    • 3.1 常规文档流
    • 3.2 盒模型
    • 3.3 元素的高度
    • 3.4 负的外边距
    • 3.5 外边距折叠
    • 3.6 容器内的元素间距问题
    • 3.7 本章小结
  • 第四章 Flexbox 布局(已完结)
    • 4.1 Flexbox 布局原理(已完结)
      • 4.1.1 创建一个基础的 Flexbox 菜单
      • 4.1.2 添加内边距与间隔
    • 4.2 弹性子元素的大小(已完结)
      • 4.2.1 使用 flex-basis 属性
      • 4.2.2 使用 flex-grow 属性
      • 4.2.3 使用 flex-shrink 属性
      • 4.2.4 实际应用
    • 4.3 弹性布局的方向(已完结)
      • 4.3.1 变更弹性布局的方向
      • 4.3.2 登录表单的样式设计
    • 4.4 对齐、间距等细节处理(已完结)
      • 4.4.1 理解弹性容器的属性
      • 4.4.2 理解弹性子元素的属性 ✔️
      • 4.4.3 使用对齐属性 ✔️
    • 4.5 本章小结 ✔️
  • 第五章 网格布局(精译中 ⏳)

文章目录

      • 4.4.2 理解弹性子元素的属性
        • 1. align-self 属性
        • 2. order 属性
      • 4.4.3 使用对齐属性
    • 4.5 本章小结

4.4.2 理解弹性子元素的属性

前面已经介绍过属性 flex-growflex-shrinkflex-basis 以及它们的简写属性 flex(详见 4.2 小节)。本节再介绍两个用在弹性子元素上的属性:align-selforder

1. align-self 属性

该属性控制弹性子元素在副轴方向上的对齐方式。它与设置在弹性容器上的 align-items 属性效果相同,但 align-self 可以单独给弹性子元素设置不同的对齐方式。指定初始值 auto 后,将以容器的 align-items 值为准;其他属性值则会覆盖容器上的对应设置。此外,align-self 支持的关键字还与 align-items 相同,即:flex-startflex-endstartendself-startself-endcenterstretch 以及 baseline

Flexbox 中还有一个 place-self 属性,它是 align-selfjustify-self 的简写形式。特别注意,justify-self 仅在网格布局(第 5 章将重点介绍)中使用,在弹性容器中会被忽略。

2. order 属性

正常情况下,弹性子元素会按照其在 HTML 源码中出现的顺序,从主轴起点开始,沿主轴方向进行排列。借助 order 属性,则可以变更子元素的排列顺序。其属性值可以为任意正整数或负整数。若出现重复的 order 值,则按源码顺序排列各子元素。

初始状态下,所有弹性子元素的 order 值都为 0。若值为 -1,则元素会移动到列表的开头;若值为 1,则移动到最后。这样就可以根据需求设置每个子元素的 order 值,以便重新排序。属性值之间可以不连续。

警告

请务必谨慎使用 order 属性。当屏幕上的视觉布局顺序与源码顺序差别过大时,可能会影响网站的可访问性(accessibility)。在大多数浏览器中使用 Tab 健浏览页面元素的顺序是与源码保持一致的,倘若视觉上差异过大,难免会令人费解。此外,视力受损的用户所使用的大部分屏幕阅读器也是基于页面源码顺序来实现各种功能的。

4.4.3 使用对齐属性

本节将利用前面介绍的这些 Flexbox 属性来给本章的示例页面画上一个圆满的句号。示例中的最后一个板块包含一个带样式的价格以及一个引导(即 call-to-action,缩写为 CTA,又译为行动召唤)按钮。最终效果如图 4.21 所示。

图 4.21 应用 Flexbox 布局实现的文字效果

图 4.21 应用 Flexbox 布局实现的文字效果

该板块的 HTML 标记已在页面写好了,如下所示:

<div class="tile centered">
  <small>Starting at</small>
  <div class="cost">
    <span class="cost-currency">$</span>
    <span class="cost-dollars">20</span>
    <span class="cost-cents">.00</span>
  </div>
  <a class="cta-button" href="/pricing">
    Sign up
  </a>
</div>

$20.00 字样包裹在元素 <div class="cost"> 中,该元素可视为弹性容器。它有三个弹性子元素,分别对应需要设置对齐方式的三处文字部分(即 $20 以及 .00)。这里选用 span 元素而非 div 来放置文本,因为 span 本就是行内元素。这样,即便因为某些原因无法加载 CSS,文本 $20.00 也依旧能在同一行进行显示。

在下面的代码清单 4.11 中,我利用了 justify-content 属性让弹性子元素在弹性容器内水平居中。然后再用 align-itemsalign-self 令它们垂直对齐。将这些样式更新到本地示例页,查看最终效果。

代码清单 4.11 价格板块的样式设计

.centered {
  text-align: center;
}
 
.cost {
  display: flex;
  justify-content: center;  /* 在主轴方向上居中对齐 */
  align-items: center;  /* 在副轴方向上居中对齐 */
  line-height: 0.7;
}

/* 给价格的不同部分设置不同的字号 */
.cost-currency {
  font-size: 2rem;
}
.cost-dollars {
  font-size: 4rem;
}
.cost-cents {
  font-size: 1.5rem;
  align-self: flex-start;  /* 覆盖该元素的 align-items 设置,令其与容器顶部而非中间部分对齐 */
}
 
.cta-button {
  display: block;
  background-color: #cc6b5a;
  color: white;
  padding: 0.5em 1em;
  text-decoration: none;
}

以上代码对带样式的标价部分 $20.00 应用了 Flexbox 布局,同时定义了一个 centered 类来居中剩下的文字,最后借助样式类 cta-button 为 CTA 引导按钮设置了对应样式。

代码中有个比较特殊的样式声明:line-height: 0.7。这是因为每个弹性子元素的文字行高决定了各子元素的高度。也就是说,元素高度要比文字本身的高度略高一些。因为 1em 的高度包含了文字内容的下行部分(descenders),而示例中的文字刚好没有,于是实际字符要比 1em 略矮一些。经过反复尝试,直到 20 的顶部与 .00 在视觉上对齐,才得到这个样式值。想了解更多文本相关的内容,请参考本书第 13 章。

Flexbox 的出现是 CSS 的一大进步。一旦熟悉,就可能想在页面的每个地方都用用看。算是给你个提醒吧:多多拥抱常规文档流,Flexbox 仅在必要的时候再考虑使用。这样讲并不是不让您用 Flexbox,而是希望您不要拿着锤子满世界找钉子。


4.5 本章小结

  • 弹性容器的各个子元素即弹性子元素(flex items),将在浏览器中排成一行或一列。
  • 简写属性 flex 指定了 flex-growflex-shrinkflex-basis 的值,可用于设置弹性子元素的大小尺寸。
  • 嵌套的弹性盒子既可以用于构建复杂的网页布局,又可以用来填满自适应大小的盒子高度。
  • Flexbox 可以自动创建等高列。
  • Flexbox 具备的多个配置属性,能够以数不清的方式灵活设置各弹性子元素的对齐方式及其间距。
  • 利用 align-itemsalign-self 属性可以在弹性容器内垂直居中某个单独的弹性子元素。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2119874.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[MySQL表的增删改查-进阶]

&#x1f308;个人主页&#xff1a;努力学编程’ ⛅个人推荐&#xff1a; c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构&#xff0c;刷题刻不容缓&#xff1a;点击一起刷题 &#x1f319;心灵鸡汤&#xff1a;总有人要赢&#xff0c;为什么不能是我呢 &#x1f4bb…

【拥抱AI】主流平台AI Agent使用体验对比

为了更好的了解和学习RAG的原理和实战效果&#xff0c;也因为工作需要&#xff0c;这两天都奔波在各大主流AI平台。 以下自己收集的是一些主流大模型LLM的AI Agent对比&#xff0c;通过功能特性、易用性与集成性、成本与商业模式、安全性与隐私性几个方面来了解&#xff0c;有不…

LSP协议:打造流动性管理的市场新标杆

随着以太坊从 PoW&#xff08;工作量证明&#xff09;向 PoS&#xff08;权益证明&#xff09;的转型&#xff0c;PoS已然成为主流区块链共识机制的重要组成部分。再加上跨链技术的发展&#xff0c;包含比特币在内的不同生态之间进行资产质押与交换也催生出市场对于流动性管理的…

CentOS Stream 8中安装和使用 Docker

docker安装包-CSDN博客 〇、常用的docker命令 docker的作用&#xff1a; 快速进行软件的安装&#xff0c;便于软件环境的维护 docker的镜像: 压缩了指定软件的安装包的文件。使用镜像文件创建容器 docker的容器: 容器可以理解为就是一台小电脑。安装的linux系统&am…

《OpenCV计算机视觉》—— 对图片进行旋转的两种方法

文章目录 一、用numpy库中的方法对图片进行旋转二、用OpenCV库中的方法对图片进行旋转 一、用numpy库中的方法对图片进行旋转 numpy库中的 np.rot90 函数方法可以对图片进行旋转 代码实现如下&#xff1a; import cv2 import numpy as np# 读取图片 img cv2.imread(wechat.jp…

[基金理财] 投资组合的搭建

&#x1f4e2;博客主页&#xff1a;https://loewen.blog.csdn.net&#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;本文由 丶布布原创&#xff0c;首发于 CSDN&#xff0c;转载注明出处&#x1f649;&#x1f4e2;现…

(CVPR-2023)面向实用的即插即用扩散模型

面向实用的即插即用扩散模型 Paper Title&#xff1a;Towards Practical Plug-and-Play Diffusion Models Paper是Riiid AI Research发表在CVPR 2023的工作 paper地址 Code地址 Abstract 基于扩散的生成模型在图像生成方面取得了显著的成功。它们的指导公式允许外部模型即插即…

PX4软/硬件(SITL/HITL)在环仿真

文章目录 介绍依赖PX4 Firmware&#xff1a; 软件在环(SITL)仿真Gazebo 软件无人机STIL连接简要示意SITL SLAM仿真总结示例 HITL 仿真 pxh常用命令MAVLink 指令使用这些命令时的注意事项 参考链接 介绍 为https://blog.csdn.net/weixin_41469272/article/details/117919845的补…

【买卖股票系列问题 -- 动规 + 其他转换方法】

目录&#xff1a; 前言买卖股票的最佳时机题解1&#xff1a;找出最值区间题解2&#xff1a;问题转化&#xff1a;最大子序和题解3&#xff1a;动态规划 买卖股票的最佳时机 II题解1&#xff1a;动态规划题解2&#xff1a;贪心 买卖股票的最佳时机含冷冻期动态规划 买卖股票的最…

Java代码审计篇 | ofcms系统审计思路讲解 - 篇1 | 环境搭建、路由机制

文章目录 Java代码审计篇 | ofcms系统审计思路讲解 - 篇1 | 环境搭建、路由机制1. 前言2. 项目环境搭建3. 项目路由机制3.1. 1&#xff09;先搜索pom.xml文件&#xff0c;看看使用了什么框架3.2. 2&#xff09;确定是否是spring的路由机制3.3. 3&#xff09;确定自写路由机制的…

双指针(7)_单调性_三数之和

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 双指针(7)_单调性_三数之和 收录于专栏【经典算法练习】 本专栏旨在分享学习C的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 1. 题目…

【Redis】redis5种数据类型(string)

目录 redis5种数据类型和内部编码方式 redis单线程模型 string字符串类型相关命令 SET GET MSET MGET SETNX SETEX ​编辑PSETEX value值为整数&#xff0c;进行加减操作 INCR INCRBY DECR DECRBY INCRBYFLOAT APPEND GETRANGE SETRANGE STRLEN string的…

VMwareWorkstation安装UOS系统(1070版本)教程

UOS系统是一款国产信创操作系统。目前市面上主流的系统版本是1070&#xff0c;下面我们用虚拟机来安装一下这款系统。 创建虚拟机 首先&#xff0c;我们先打开VMwareWorkstation软件&#xff0c;新建虚拟机 选择自定义&#xff0c;点击下一步 点击下一步 选择稍后安装操作系统…

【通信管理之c++基础01】std::future

std::future https://en.cppreference.com/w/cpp/thread/future https://cplusplus.com/reference/future/future/ std::async #

实验一 局域网设计

一、实验目的 1.掌握网络工程中需求分析方法。 2.子网IP地址规划及子网间互相通信的方法。 3.掌握局域网的构建方法。 二、实验描述 某中学拟建设一个校园网&#xff0c;网络使用192.168.10.0/24这个地址段。计算机主要分布如下&#xff1a;两个学生机房各为10台&#xff…

数据库课程 CMU15-445 2023 Fall Project-0 项目记录

0. 实验结果 1. 环境配置 1.1 虚拟机Ubuntu 22.04.4 LTS 1.2 Vscode 插件安装clangd&#xff1a;代码补全 1.3 参考官方Project 0完成环境配置 1.4 获取到的代码&#xff0c;切换分支到2023 Fall git checkout fc57dab // 仓库中2023 Fall release版本的哈希值 git branch d…

WPF 保姆级教程怎么实现一个树形菜单

先看一下效果吧: 我们直接通过改造一下原版的TreeView来实现上面这个效果 我们先创建一个普通的TreeView 代码很简单: <TreeView><TreeViewItem Header"人事部"/><TreeViewItem Header"技术部"><TreeViewItem Header"技术部-1&q…

低代码平台:助力企业数字化转型的利器

正文&#xff1a; 在数字化时代的浪潮中&#xff0c;企业需要快速适应市场变化和技术进步。传统的软件开发方法往往由于开发周期长、成本高和对技术人员的依赖程度高&#xff0c;难以满足企业的快速响应需求。此时&#xff0c;低代码平台&#xff08;Low-Code Platform&#x…

干货分享|分享一款微软出品的工作效率神器 PowerToys

工具介绍&#xff1a;Microsoft PowerToys 是一组实用工具&#xff0c;可帮助高级用户调整和简化其 Windows 体验&#xff0c;从而提高工作效率。 安装步骤&#xff1a;直接打开微软商店安装即可&#xff0c;并且可以保证下载到最新版本。 功能介绍&#xff1a; 高级粘贴 高级…

js react 笔记 2

起因&#xff0c; 目的: 记录一些 js, react, css 1. 生成一个随机的 uuid // 需要先安装 crypto 模块 const { randomUUID } require(crypto);const uuid randomUUID(); console.log(uuid); // 输出类似 9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d 2. 使用 props, 传递参数…