當運算式的值改變時,Key 區塊會銷毀並重新建立其內容。如果您希望元素在值改變時播放其轉場,而不是僅在元素進入或離開 DOM 時才播放,這會很有用。
例如,在這裡,我們希望在載入訊息(即 i
)改變時,播放來自 transition.js
的 typewriter
轉場。將 <p>
元素包裹在 key 區塊中
App
{#key i}
<p in:typewriter={{ speed: 10 }}>
{messages[i] || ''}
</p>
{/key}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<script>
import { typewriter } from './transition.js';
import { messages } from './loading-messages.js';
let i = $state(-1);
$effect(() => {
const interval = setInterval(() => {
i += 1;
i %= messages.length;
}, 2500);
return () => {
clearInterval(interval);
};
});
</script>
<h1>loading...</h1>
<p in:typewriter={{ speed: 10 }}>
{messages[i] || ''}
</p>