- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有这个代码:
<p style="line-height: 1;overflow: hidden;">blah_blah</p>
<p>blah_blah</p>
<p style="line-height: 1;overflow: hidden;">qypj;,</p>
<p>qypj;,</p>
结果是(注意没有下划线,并剪切字符):
也就是说,它在 Firefox(Windows 10 上的 66.0.3)中以这种方式运行。其他浏览器似乎呈现下划线。上面的代码片段运行程序似乎也可以工作(即使在 Firefox 中),除非您在“整页”中运行它。
这个Q类似于Text changes height after adding unicode character除了这里没有技巧。 “_”只是一个简单的 ASCII 字符。
我的问题是哪种行为是正确的。是否允许特定字符更改行高(我认为它只应该与字体相关)? line-height: 1
不应该暗示它可以完全适合任何文本吗?
我想有些字符是特殊的,例如“p”、“g”、“j”(可能还有“_”),它们绘制在它的线下方。仍然是哪种行为是正确的。算不算溢出?
PS:此外,我觉得要么 overflow-x: hidden;overflow-y: visible;
和overflow-x: visible;overflow-y 很有趣: hidden;
仍然会导致这个。这对我来说更像是一个真正的错误。
最佳答案
My question is which behavior is the correct one.
所有这些都是正确的,因为我们在所有浏览器中都没有相同的默认字体,而且它也因操作系统而异。
Is specific character allowed to change line height (I thought it was only supposed to be font dependent)?
字符不会改变行高
。更准确地说,line-height
是一个只能通过设置 line-height
来更改的属性,但您可能会混淆由 line-height
单独一个字符不能改变它。
Shouldn't line-height: 1 imply it can fit exactly any text?
不一定,line-height:1
表示行框将等于1xfont-size
1 但是字体旨在包括这个空间内的所有 Angular 色?他们中的大多数人可能会这样做,但我们不知道。
基本上,您需要考虑两件事。由字体属性定义的内容区域和由行高定义的行框。我们无法控制第一个,我们只能控制第二个。
这里有一个基本的例子来说明:
span {
background:red;
color:#fff;
font-size:20px;
font-family:monospace;
}
body {
margin:10px 0;
border-top:1px solid;
border-bottom:1px solid;
animation:change 2s linear infinite alternate;
}
@keyframes change {
from {
line-height:0.2
}
to {
line-height:2
}
}
<span >
blah_blah
</span>
红色是我们的内容区域,它的高度由字体属性定义,如果您检查该元素,您会看到它的高度等于 23px
(不是 20px
像 font-size
) 和边框定义了我们使用行高控制的行框。
因此,如果 line-height
等于 1,我们将有一个等于 20px
的行框,这不足以包含 23px
内容区域因此它会被截断,我们可能会隐藏一些合乎逻辑的字符(或其中的一部分):
span {
background: red;
color: #fff;
font-size: 20px;
font-family: monospace;
}
body {
margin: 5px;
line-height: 1;
overflow:hidden;
}
html {
overflow:auto;
}
<span>
blah_blah ÂÄ j p
</span>
不同的 font-size
将删除 Firefox 中的下划线:
span {
background: red;
color: #fff;
font-size: 26px;
font-family: monospace;
}
body {
margin: 5px;
line-height: 1;
overflow:hidden;
}
html {
overflow:auto;
}
<span>
blah_blah ÂÄ j p
</span>
另一个使用谷歌字体的例子,结果应该是相同的跨浏览器。下划线可见,但 ^
/¨
span {
background: red;
color: #fff;
font-size: 26px;
font-family: 'Gugi', cursive;
}
body {
margin: 5px;
line-height: 1;
overflow:hidden;
}
html {
overflow:auto;
}
<link href="https://fonts.googleapis.com/css?family=Gugi" rel="stylesheet">
<span>
blah_blah ÂÄ j p
</span>
另一个下划线不可见的例子:
span {
background: red;
color: #fff;
font-size: 27px;
font-family: 'PT Sans', sans-serif;
}
body {
margin: 5px;
line-height: 1;
overflow:hidden;
}
html {
overflow:auto;
}
<link href="https://fonts.googleapis.com/css?family=PT+Sans" rel="stylesheet">
<span>
blah_blah ÂÄ j p
</span>
你可以清楚地看到,每次我们使用不同的字体时,我们都会有不同的溢出,这证实了这是字体相关的。除非我们知道字体是如何设计的,否则我们无法控制它。
相关问题:
Understanding CSS2.1 specification regarding height on inline-level boxes
Why is there space between line boxes, not due to half leading?
Line height issue with inline-block elements
这是一篇获得更准确细节和计算的好文章:https://iamvdo.me/en/blog/css-font-metrics-line-height-and-vertical-align
引用这篇文章:
It becomes obvious that setting
line-height: 1
is a bad practice. I remind you that unitless values are font-size relative, not content-area relative, and dealing with a virtual-area smaller than the content-area is the origin of many of our problems.
1 : 我考虑了一个简化的解释,但实际上行框的计算不仅与行高属性有关。
关于html - 特定文本字符可以更改行高吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55978130/
我有一个功能是转换 ADO Recordset 进入html: class function RecordsetToHtml(const rs: _Recordset): WideString; 该函
经过几天的研究和讨论,我想出了这种方法来收集访客的熵(你可以看到我的研究历史here) 当用户访问时,我运行此代码: $entropy=sha1(microtime().$pepper.$_SERVE
给定一个无序列表 List ,我需要查找是否存在 String与提供的字符串匹配。 所以,我循环 for (String k : keys) { if (Utils.keysM
我已经搜索过这个问题,但没有找到我正在寻找的答案。 基本上,我想将类构造函数包装在 try/except 子句中,以便它忽略构造函数内特定类型的错误(但无论如何都会记录并打印它们)。我发现做到这一点的
我有一组三个数字,我想将一组数字与另一组数字进行比较。即,第一组中的每个数字小于另一组中的至少一个数字。需要注意的是,第一组中的下一个数字必须小于第二组中的不同数字(即,{6,1,6} 对 {8,8,
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
首先介绍一下背景: 我正在开发一个带有 EJB 模块和应用程序客户端模块的企业应用程序 (ear)。我还使用 hibernate JPA 来实现持久性,并使用 swingx 来实现 GUI。这些是唯一
我正在尝试在我的上网本上运行 Eclipse 以便能够为 Android 进行开发。 您可能已经猜到了,Eclipse 非常慢,并且不容易有效地开发。 我正在使用 Linux Ubuntu 并且我还有
for row, instrument in enumerate(instruments): for col, value in enumerate(instrument):
return not a and not b ^ 我如何以更好的格式表达它 最佳答案 DeMorgan's Law , 也许? return not (a or b) 我认为在这一点上已经足够简单了
我正在尝试让 Font Awesome 图标看起来更 slim https://jsfiddle.net/cliffeee/7L6ehw9r/1/ . 我尝试使用“-webkit-text-strok
假设我有一个名为 vals 的数据框,如下所示: id…………日期…………min_date…… .........最大日期 1…………2016/01/01…………2017/01/01…………2018/
是否有更 Pythonic 的方式来做到这一点?: if self.name2info[name]['prereqs'] is None: se
我有一个函数可以将一些文本打印到它接收到的 ostream&。如果 ostream 以终端为目标,我想让它适应终端宽度,否则默认为某个值。 我现在做的是: 从 ostream 中获取一个 ofstre
这个问题在这里已经有了答案: Should a retrieval method return 'null' or throw an exception when it can't produce
我有这个 bc = 'off' if c.page == 'blog': bc = 'on' print(bc) 有没有更 Pythonic(和/或更短)的方式在 Python 中编写? 最佳
输入:一个包含 50,000 行的 CSV;每行包含 910 列值 0/1。 输出:运行我的 CNN 的数据框。 我编写了一个逐行读取 CSV 的代码。对于每一行,我将数据分成两部分,称为神经元(90
据我所知,with block 会在您退出 block 后自动调用 close(),并且它通常用于确保不会忘记关闭一个文件。 好像没有技术上的区别 with open(file, 'r+') as f
我有一个使用 Entity Framework V6.1.1 的 MVC 5 网站。 Entity Framework DbContext 类和模型最初都在网站项目中。这个项目有 3 个 DbCont
我是编程新手,在尝试通过将 tableView 和关联 View 的创建移动到单独的类并将委托(delegate)和数据源从 VC 移动到单独的类来精简我的 ViewController 时遇到了一些
我是一名优秀的程序员,十分优秀!