blob: 5bbc45ee407f6c537e870d3db78478b36a58dea0 (
plain)
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>
<title>Testcase, bug 1209603</title>
<style>
p {
font-size: 2em;
/* ensure font-size dependency in the margin struct; this is also in
the UA style sheet, but repeated here for clarity */
margin: 1em 0;
}
</style>
<div style="font-size: 20px"><p id="a">Should be 40px font size.</p></div>
<script>
var a = document.getElementById("a");
// force computation of the margin struct on A (caching in rule tree)
getComputedStyle(a, "").marginTop;
</script>
<!-- will dynamically change font-size to 10px later;
also needs to be different from 20px now to avoid sibling-sharing -->
<div style="font-size: 30px"><p id="b">Should be 20px font size.</p></div>
<script>
// Note that A and B share rule nodes, and note that the margin struct
// has been conditionally (on font size) cached on their shared rule node.
var b = document.getElementById("b");
// force style context construction and computation of the font struct on
// B's parent
getComputedStyle(b.parentNode, "").fontSize;
// force style context construction (and computation of the color
// struct) on B, but not the margin struct or font struct
getComputedStyle(b, "").color;
// restyle B and flush
b.parentNode.style.fontSize = "10px";
getComputedStyle(b, "").marginTop;
// This flush will call CalcStyleDifference on B, which will find no
// cached font struct on the old context, but which will find a
// cached margin struct on the rule node.
</script>
|