1 <title>Select element scrolling when in transformed container
</title>
6 if (window
.testRunner
) {
7 testRunner
.dumpAsText();
8 testRunner
.waitUntilDone();
11 var triggers
= document
.querySelectorAll(".scrollTrigger");
12 for (var i
=0; i
< triggers
.length
; i
++) {
13 triggers
[i
].scrollIntoView();
15 document
.getElementById("c-inner").scrollIntoView(true);
16 document
.getElementById("d-inner").scrollIntoView(false);
18 var selectElements
= document
.querySelectorAll("select");
19 for (i
=0; i
< selectElements
.length
; i
++) {
20 selectElements
[i
].focus();
23 var resultString
= "";
24 var id1
, id2
, element1
, element2
, scrollTop1
, scrollTop2
;
26 // The test results should be (for scrollTop)
35 element1
= document
.getElementById(id1
);
36 element2
= document
.getElementById(id2
);
37 element3
= document
.getElementById(id3
);
38 element4
= document
.getElementById(id4
);
39 scrollTop1
= element1
.scrollTop
;
40 scrollTop2
= element2
.scrollTop
;
41 scrollTop3
= element3
.scrollTop
;
42 scrollTop4
= element4
.scrollTop
;
43 if (scrollTop1
!= scrollTop2
) {
44 resultString
+= "PASS - Element " + id1
+ " and Element " + id2
+ " had different scrollTop<br>";
46 resultString
+= "FAIL - Element " + id1
+ " and Element " + id2
+ " had identical scrollTop<br>";
49 if (scrollTop2
== 0) {
50 resultString
+= "PASS - Element " + id2
+ " had scrollTop: 0<br>";
52 resultString
+= "FAIL - Element " + id2
+ " had a non-zero scrollTop: " + scrollTop2
+ "<br>";
55 if (scrollTop3
== scrollTop4
) {
56 resultString
+= "PASS - Element " + id3
+ " and Element " + id4
+ " had same scrollTop<br>";
58 resultString
+= "FAIL - Element " + id3
+ " and Element " + id4
+ " had different scrollTop<br>";
61 var results
= document
.getElementById("results");
62 results
.innerHTML
= resultString
;
64 if (window
.testRunner
) {
65 testRunner
.notifyDone();
70 <style type=
"text/css" media=
"screen">
76 display: inline-block;
83 background-color: blue;
91 background-color: red;
100 transform: translateY(-
300px);
105 background-color: red;
107 transform: scaleY(
2.0);
110 <body onload=
"test()">
112 Testing the scrolling behaviour of elements when in a normal and transformed container.
113 On the left is the normal container. On the right are containers containing transformed elements.
114 To test this manually, click on the two select elements. The menu popup should
115 appear directly over the element - the content should not move.
<br>
116 The third and fourth containers tests that scrollIntoView(false) works properly in the presence of a scaled element. Because the element is at the bottom of the container, scrollIntoView should give the same result regardless of flag.
119 <div class=
"container" id=
"a">
120 <div class=
"scrolled">
122 Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
125 Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
130 <option>three
</option>
131 <option>four
</option>
136 <div class=
"container" id=
"b">
137 <div class=
"scrolled offset">
139 Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
142 Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
147 <option>three
</option>
148 <option>four
</option>
153 <div class=
"container" id=
"c">
154 <div class=
"padding"></div>
155 <div class=
"scaled" id=
"c-inner">
156 <p>This text should not be cut off
</p>
160 <div class=
"container" id=
"d">
161 <div class=
"padding"></div>
162 <div class=
"scaled" id=
"d-inner">
163 <p>This text should not be cut off
</p>