メインコンテンツにスキップ

clientWidthclientHeightoffsetWidthoffsetHeightのバインディングを任意の要素に追加できます。SvelteはResizeObserverを使ってバインドされた値を更新します。

App
<div bind:clientWidth={w} bind:clientHeight={h}>
	<span style="font-size: {size}px" contenteditable>{text}</span>
	<span class="size">{w} x {h}px</span>
</div>

これらのバインディングは読み取り専用です。whの値を変更しても、要素には影響しません。

display: inline要素は(<img><canvas>のような「固有」の寸法を持つ要素を除き)幅や高さを持ちません。また、ResizeObserverで観測することもできません。これらの要素のdisplayスタイルをinline-blockのような他のものに変更する必要があります。

GitHubでこのページを編集

前へ 次へ
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
<script>
	let w = $state();
	let h = $state();
	let size = $state(42);
</script>
 
<label>
	<input type="range" bind:value={size} min="10" max="100" />
	font size ({size}px)
</label>
 
<div>
	<span style="font-size: {size}px" contenteditable>
		edit this text
	</span>
 
	<span class="size">{w} x {h}px</span>
</div>
 
<style>
	div {
		position: relative;
		display: inline-block;
		padding: 0.5rem;
		background: hsla(15, 100%, 50%, 0.1);
		border: 1px solid hsl(15, 100%, 50%);
	}
 
	.size {
		position: absolute;
		right: -1px;
		bottom: -1.4em;
		line-height: 1;
		background: hsl(15, 100%, 50%);
		color: white;
		padding: 0.2em 0.5em;
		white-space: pre;
	}
</style>