File: dragstart-change-selection-offscreen.html

package info (click to toggle)
webkit2gtk 2.34.6-1~deb10u1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 262,936 kB
  • sloc: cpp: 2,410,633; javascript: 191,866; ansic: 97,227; xml: 65,800; python: 30,274; ruby: 17,137; perl: 15,396; asm: 9,345; yacc: 2,309; sh: 1,660; lex: 1,293; java: 726; makefile: 106; pascal: 60
file content (33 lines) | stat: -rw-r--r-- 756 bytes parent folder | download | duplicates (14)
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
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<style>
body {
    font-size: 200px;
}

#offscreen {
    position: absolute;
    top: -500vh;
    left: -500vw;
}
</style>
</head>
</body>
<div id="onscreen">DRAG ME</div>
<div id="offscreen">FAR OFFSCREEN</div>
<script>
function selectChildNodesOfElement(element)
{
    let range = document.createRange();
    range.setStartBefore(element.childNodes[0])
    range.setEndAfter(element.childNodes[element.childNodes.length - 1]);
    getSelection().removeAllRanges();
    getSelection().addRange(range);
}
selectChildNodesOfElement(onscreen);
document.body.addEventListener("dragstart", () => selectChildNodesOfElement(offscreen));
</script>
</body>
</html>