File: line-clamp-auto-032.tentative.html

package info (click to toggle)
firefox 143.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,617,328 kB
  • sloc: cpp: 7,478,492; javascript: 6,417,157; ansic: 3,720,058; python: 1,396,372; xml: 627,523; asm: 438,677; java: 186,156; sh: 63,477; makefile: 19,171; objc: 13,059; perl: 12,983; yacc: 4,583; cs: 3,846; pascal: 3,405; lex: 1,720; ruby: 1,003; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 53; csh: 10
file content (50 lines) | stat: -rw-r--r-- 1,421 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
<!DOCTYPE html>
<meta charset="utf-8">
<title>CSS Overflow: `line-clamp: auto` margin collapsing accounts for self-collapsing boxes</title>
<link rel="author" title="Andreu Botella" href="mailto:abotella@igalia.com">
<link rel="help" href="https://drafts.csswg.org/css-overflow-4/#line-clamp">
<link rel="match" href="reference/line-clamp-auto-032-ref.html">
<meta name="assert" content="With `line-clamp: auto`, if a clamp point might fall inside a box, its margins are accounted for correctly. This is the case even for self-collapsing boxes before the clamp point.">
<style>
.clamp {
  line-clamp: auto;
  max-height: calc(4lh + 2 * 5px);
  font: 16px / 32px serif;
  background-color: orange;
}
.inner {
  white-space: pre;
  margin: 5px;
  background-color: yellow;
}
.collapse-through {
  margin: 5px;
}
.abspos {
  position: absolute;
  right: 0;
  height: 100px;
  width: 100px;
  background-color: skyblue;
}
</style>

<!--
  The bottom margins of both the first `.inner` and of `.collapse-through` end
  at the clamp boundary, since the bottom margin of `.inner` collapses through
  `.collapse-through`. This also puts the static position of `.abspos` at the
  clamp boundary, which means it will be visible.
-->

<div class="clamp">
<div class="inner">Line 1
Line 2
Line 3
Line 4</div>
<div class="collapse-through"></div>
<div class="abspos"></div>
<div class="inner">Line 5
Line 6
Line 7
Line 8</div>
</div>