在 DOM 中,每个输入值都是字符串。这在处理数值输入(type="number"
和 type="range"
)时会带来不便,因为这意味着必须记得在使用 input.value
之前进行类型转换。
使用 bind:value
,Svelte 会自动帮你处理这个问题:
App
<label>
<input type="number" bind:value={a} min="0" max="10" />
<input type="range" bind:value={a} min="0" max="10" />
</label>
<label>
<input type="number" bind:value={b} min="0" max="10" />
<input type="range" bind:value={b} min="0" max="10" />
</label>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<script>
let a = $state(1);
let b = $state(2);
</script>
<label>
<input type="number" value={a} min="0" max="10" />
<input type="range" value={a} min="0" max="10" />
</label>
<label>
<input type="number" value={b} min="0" max="10" />
<input type="range" value={b} min="0" max="10" />
</label>
<p>{a} + {b} = {a + b}</p>