File: text-box-trim-initial-letter-start-001-ref.html

package info (click to toggle)
firefox-esr 140.4.0esr-1~deb13u1
  • links: PTS, VCS
  • area: main
  • in suites: trixie-proposed-updates
  • size: 4,539,284 kB
  • sloc: cpp: 7,381,286; javascript: 6,388,710; ansic: 3,710,139; python: 1,393,780; xml: 628,165; asm: 426,916; java: 184,004; sh: 65,742; makefile: 19,302; objc: 13,059; perl: 12,912; yacc: 4,583; cs: 3,846; pascal: 3,352; lex: 1,720; ruby: 1,226; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (29 lines) | stat: -rw-r--r-- 974 bytes parent folder | download | duplicates (7)
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
<!DOCTYPE html>
<link rel="stylesheet" type="text/css" href="/fonts/ahem.css" />
<style>
.spacer {
  height: 50px;
  background: lightgray;
}
.target {
  font: 40px/1 Ahem;
  position: relative;
}
.target::first-letter {
  initial-letter: 2 1;
}
</style>
<div class="spacer"></div>
<div class="target">ApÉx</div>
<script>
// The font size of raised initial letters is undefined[1].
// Implementations, especially when using Ahem as a web font, don't match.
// To test the `text-box-trim` behavior by ignoring such differences, compute
// the expected position of the `target` dynamically.
// [1] https://drafts.csswg.org/css-inline-3/#sizing-initial-letter
const spacer = document.getElementsByClassName('spacer')[0];
const target = document.getElementsByClassName('target')[0];
const spacer_bottom = spacer.getBoundingClientRect().bottom;
const target_bottom = target.getBoundingClientRect().bottom;
target.style.top = `${spacer_bottom - target_bottom + 40}px`;
</script>