Svelte stores派生

2023-02-21 16:08 更新

你可以創(chuàng)建一個stores,其內(nèi)的值可以派生(derived)于一個或多個 其他 stores。在前面的示例的基礎(chǔ)上,我們可以創(chuàng)建派生時間到其他頁面:

export const elapsed = derived(
	time,
	$time => Math.round(($time - start) / 1000)
);

可以從多個源派生?stores?, 并顯式用??set??指定它的值而不是返回它(這對異步調(diào)用的派生值很有用)。 更多請查閱API 參考 。

示例代碼

  • App.svelte

<script>
	import { time, elapsed } from './stores.js';

	const formatter = new Intl.DateTimeFormat('en', {
		hour12: true,
		hour: 'numeric',
		minute: '2-digit',
		second: '2-digit'
	});
</script>

<h1>The time is {formatter.format($time)}</h1>

<p>
	This page has been open for
	{$elapsed} {$elapsed === 1 ? 'second' : 'seconds'}
</p>

  • stores.js

import { readable, derived } from 'svelte/store';

export const time = readable(new Date(), function start(set) {
	const interval = setInterval(() => {
		set(new Date());
	}, 1000);

	return function stop() {
		clearInterval(interval);
	};
});

const start = new Date();

export const elapsed = derived(
	time,
	$time => Math.round(($time - start) / 1000)
);


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號