Skip to main content

イベントリスナーを任意の DOM 要素に追加できるのと同じように、window オブジェクトにも <svelte:window> でイベントリスナーを追加できます。

すでに handleKeydown 関数を宣言しているので、あとは keydown リスナーを追加するだけです:

App.svelte
<svelte:window on:keydown={handleKeydown} />

DOM要素と同様に preventDefault のようなイベント修飾子を追加することができます。

Next: <svelte:window> bindings

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
<script>
	let key;
	let keyCode;
 
	function handleKeydown(event) {
		key = event.key;
		keyCode = event.keyCode;
	}
</script>
 
<svelte:window />
 
<div style="text-align: center">
	{#if key}
		<kbd>{key === ' ' ? 'Space' : key}</kbd>
		<p>{keyCode}</p>
	{:else}
		<p>Focus this window and press any key</p>
	{/if}
</div>
 
<style>
	div {
		display: flex;
		height: 100%;
		align-items: center;
		justify-content: center;
		flex-direction: column;
	}
 
	kbd {
		border-radius: 4px;
		font-size: 6em;
		padding: 0.2em 0.5em;
		background-color: #eeeeee;
		border-top: 5px solid #f9f9f9;
		border-left: 5px solid #f9f9f9;
		border-right: 5px solid #aaaaaa;
		border-bottom: 5px solid #aaaaaa;
		color: #555;
	}
</style>
 
initialising