深入理解css行高line-height

article/2025/5/15 8:26:04

1.行高的定义

行高是相邻两行文本基线之间的垂直距离。看清楚是基线,估计有很多前端搞了几年的都说不出个所以然。小时候我们写英文26个英文字母的单词本(随便找个图)
在这里插入图片描述
一行里面有四条线,在css中一个行内非替换元素(例如span,em等),其内容区都会存在四条假想的线,分别是底线(bottom)、基线(baseline)、中线(middle)、顶线(top),它们就类似于书写英文时的四条线,其中两红色的线的垂直距离就是行高,通过换算一下,行高 = 顶线到底线的垂直距离+行间距(就是传说中的控制两行文字之前的垂直距离,可以分我上半行距和下半行距)。其实顶线到底线的垂直距离取决font-size的大小,此区域为内容区域(content area)。有个概念就可以,下面我会慢慢分析。

2.css boxes各种类型

先看一段代码:

 <p><em>Health</em> <span>is the most important thing </span> in the world
</p>

效果如下:
在这里插入图片描述
这断代码中设计到4种boxes:

1.containing box(包含盒子)

这个是最大的也是最外层的box,你可以把它理解为一个段落(一个段落里面很多行),它包含了其他的boxes。

2.line boxes(行框盒子)

刚上面说了,段落下面的就是行,一个段落是由若干行组成的。

3.inline boxes(内联盒子)

内联盒子不会让内容成块显示,而是排成一行,像例子中的span,em就是内联盒子,如果没有标签包裹的 'in the world’属于匿名内联盒子。多个内联盒子就形成了行框盒子,就相当多个字组合起来就形成了行。

4.content area(内容区域)

这个上面提到过,是围绕着文字看不见的区域box,这个区域取决font-size的大小,行高就等于文字大小+行间距。比如:line-heigt:20px,font-size:16px。算出间距4px。
在这里插入图片描述
那是不是inline box就和行高高度是一样,正常情况是一样,如果line-heigt比font-size小,那么inline box会优先行高,再如果有替换元素(img,input等)例如img插入图片,图片的高度比line-height高,那么inline box会是图片的高度。既然知道了inline box高度,之前说过多个inline box组成line box,所以line box高度取决于内部最高的inline box,有很多种可能(line-height最高的,或者font-size最大的,或者图片最高的)。

3.line-height的用法

,以下图的结构为例子来分析下面五种定义line-height方式:

在这里插入图片描述

1.normal

首先各个浏览器都有个默认的line-height(一般1.0到1.4),这个ine-height值可以理解为固定的纯数字,行高都是当前font-size乘于这个固定值。如果子代不重写line-height的话,这个是会继承的(下面浏览器默认的line-height等于1.2为例子)。
在这里插入图片描述

2.inherit

继承,这个就不用说了,默认就是inherit。

3.百分比

当父设置百分比,父的行高为当前font-size乘于这个百分比,如果子代不重写line-height的话,子代的行高会继承父的行高。
在这里插入图片描述

4.固定长度(px,em等)

当父设置固定长度,父的行高为当前这个固定长度(em是相对父级字体的),如果子代不重写line-height的话,子代的行高会继承父的行高。
在这里插入图片描述

5.纯数字(理想的方式)

父和子的行高是font-size乘于这个纯数字,line-height会随着font-szie的值做相应比例缩放。
在这里插入图片描述
好了,到这里就差不多已经说完了(如果有不对之处,欢迎指正,不胜感激!!!),欢乐的时光总是过得特别快,又到时候和大家讲拜拜!!


http://chatgpt.dhexx.cn/article/nGBLF7sr.shtml

相关文章

strlen

strlen strlen计算长度 strlen计算长度 strlen在计算长度时&#xff0c;一定要注意计算的字符串中是否含有\0字符&#xff08;请注意&#xff0c;0和\0是有区别的&#xff0c;0代表数字&#xff0c;\0代表转义字符&#xff0c;值是48&#xff09;&#xff0c;比如你希望算0x12…

数字图像处理第九章——形态学图像处理

数字图像处理第九章 数字图像处理---形态学图像处理&#xff08;一&#xff09;预备知识1.1 集合理论中的基本概念1.2 二值图像、集合及逻辑算子 &#xff08;二&#xff09;膨胀和腐蚀2.1 膨胀2.2 结构元的分解2.3 strel函数2.4 腐蚀 &#xff08;三&#xff09; 膨胀与腐蚀的…

MATLAB教学_09影像处理二

本文视频地址&#xff1a;https://www.bilibili.com/video/av68228488?p9 主要学习了初阶影像处理。有三个内容&#xff1a; 图像阈值背景预测相关连的标签 计算米粒颗数 先将图片二值化。那么有米粒的区域应该是1&#xff0c;而没有的地方就是0。那么去计算有多少个一大群…

【计算机视觉】图像增强——图像的形态学操作

个人简介&#xff1a; > &#x1f4e6;个人主页&#xff1a;赵四司机 > &#x1f3c6;学习方向&#xff1a;JAVA后端开发 > ⏰往期文章&#xff1a;SpringBoot项目整合微信支付 > &#x1f514;博主推荐网站&#xff1a;牛客网 刷题|面试|找工作神器 > &#…

数字图像处理实验(七)| 形态学图像处理{生成结构元素strel、腐蚀运算imerode、膨胀运算imdilate、开运算imopen、闭运算imclose}(附代码和实验截图、汉字视力表项目、总结)

文章目录 一、实验目的二、实验仪器三、实验原理1. 结构元素&#xff1a;2. 腐蚀运算&#xff1a;3. 膨胀运算&#xff1a;4. 开运算&#xff1a;5. 闭运算&#xff1a; 四、实验内容:1. 形态学图像处理用于图像边界提取2&#xff0e;数学形态学用于图像的噪点去除&#xff08;…

【2】MATLAB中strel('disk',r)的C实现

strel 是MATLAB中常用的类型&#xff0c;即是structuring element&#xff0c;用来构建结构元素。opencv中与其相似的函数是getStructuringElement()这个函数。 这里仅仅说是相似主要是因为两者还是有很多区别的。 getStructuringElement()可以获取常用的结构元素的形状&…

matlab strel详解,【2】MATLAB中strel('disk',r)的C實現

strel 是MATLAB中常用的類型&#xff0c;即是structuring element&#xff0c;用來構建結構元素。opencv中與其相似的函數是getStructuringElement()這個函數。 這里僅僅說是相似主要是因為兩者還是有很多區別的。 getStructuringElement()可以獲取常用的結構元素的形狀&#x…

matlab strel结构元素,【matlab】Strel函数--结构元素

###Date:2018.3.28 =========================================================================== Strel函数 主要用来构建形态学运算中的结构元素,使用的语法为strel(shape,parameters)。shape为形状参数,即设置什么样的结构元素;parameters为控制形状参数大小方向的参数…

Strel函数--结构元素

Strel函数 主要用来构建形态学运算中的结构元素&#xff0c;使用的语法为strel(shape,parameters)。shape为形状参数&#xff0c;即设置什么样的结构元素&#xff1b;parameters为控制形状参数大小方向的参数。 例&#xff1a; 建立一个负向45&#xff0c;长度为6的结构元素…

strel

文章目录 SyntaxDescriptionExamplesAlgorithms 形态结构要素 strel代表平坦的形态构造元素&#xff0c;这是形态扩张和侵蚀操作的重要组成部分。 平面结构元素是二维或二维的二进制值邻域&#xff0c;其中在形态计算中包含真实像素&#xff0c;而不包含错误像素。 结构元素的中…

图像处理函数——strel、roipoly、roifilt2、roifill

文章目录 1.strel2.roipoly3.roifilt24.roifill 1.strel 功能&#xff1a; 形态学结构元素&#xff0c;strel 对象表示一个平面形态学结构元素&#xff0c;该元素是形态学膨胀和腐蚀运算的重要部分。 语法&#xff1a; SE strel(shape, parameters) 创建一个结构元素对象SE。…

nginx日志配置,以及日志轮询

一、为nginx配置错误日志 Nginx错误日志是调试nginx的重要手段&#xff0c;属于核心功能模块的参数&#xff08;ngx_core_module&#xff09;该参数名字为err_log&#xff0c;是放在Main区块中全局配置 err_log的语法格式以及参数语法说明如下 err_log file lev…

nginx配置日志记录问题

去掉nginx.conf文件里面的llog_format main注释并修改为如下 log_format main $remote_addr - $remote_user [$time_local] "$request" $status $body_bytes_sent "$http_referer" "$http_user_agent" "$http_x_forwarded_for"|&quo…

nginx服务器网站日志,nginx网站日志配置

nginx网站日志配置 [2020-09-10 10:47:43] 简介: 建站服务器 1、日志介绍nginx有两种日志&#xff0c;一种是访问日志&#xff0c;一种是错误日志。访问日志中记录的是客户端对服务器的所有请求。错误日志中记录的 建站服务器 ELK系统在安装完成后需要处理相关的日志文件&…

Linux Nginx日志——Nginx日志配置 access_log error_log rewrite_log 日志轮转

1、Nginx 日志介绍 Nginx 每个级别的配置都可以有独立的访问日志, 所需日志模块 ngx_http_log_module 的支持&#xff0c;日志格式通过 log_format 命令来定义&#xff0c;日志对于统计和排错是有利的。 nginx 日志相关的配置包括 access_log、rewrite_log、error_log# 设置访…

【Nginx 日志配置】【访问日志log_format】【错误日志error_log 指令】【Nginx的日志轮转】

文章目录 Nginx 日志配置log_format 指令中常用的一些变量&#xff1a;访问日志 案例可以配置段&#xff1a;http, stream, server, location作用域。error_log 指令 错误访问日志 级别rewrite_log 指令 用户跳转日志 一般不用配置流量控制相关功能配置日志记录 Nginx 日志配置…

关于nginx日志配置指令介绍

本文主要介绍了nginx日志配置指令详解,nginx有一个非常灵活的日志记录模式,每个级别的配置可以有各自独立的访问日志,需要的朋友可以参考下 日志对于统计排错来说非常有利的。本文总结了nginx日志相关的配置如access_log、log_format、open_log_file_cache、log_not_found、lo…

宝塔自定义nginx访问日志配置

nginx日志自定义配置 问题 有时nginx默认的日志满足不了需求&#xff0c;比如网站绑定了多个域名&#xff0c;想知道用于访问的是具体域名&#xff0c;这时候就需要自定义nginx日志了。 nginx 中access log 记录了用户访问的页面以及用户浏览器、ip和其他的访问信息 log_for…

Nginx日志配置、错误界面配置、流量控制 第九天

目录 nginx日志配置 nginx日志介绍 access.log error.log open_log_file_cache rewrite.log nginx的日志轮转 nginx错误界面配置 nginx流量控制 nginx如何限流 配置基本限流 nginx流量限制&#xff08;高级&#xff09; 流量控制相关功能 nginx日志配置 nginx日志…

运维配置:Nginx日志配置详解

Nginx日志配置详解 前言 Nginx日志对于统计、系统服务排错很有用。Nginx日志主要分为两种&#xff1a;access_log(访问日志)和error_log(错误日志)。通过访问日志我们可以得到用户的IP地址、浏览器的信息&#xff0c;请求的处理时间等信息。错误日志记录了访问出错的信息&…