Вы на правильном пути.
Сохраните цены акций как ха sh в магазине writable()
.
// in stores.js
export const stocks = writable({})
Затем, когда вы захотите обновить цена или добавить новую акцию, вы звоните stocks.update()
.
// in stores.js
export function update(symbol, data) {
// using `...` to destructure a copy, we don't want to overwrite previous value
stocks.update(({...records}) => {
// now update the copy
records[symbol] = data
// return the new value for the store, this will trigger updates in templates that subscribe
return records
})
}
В ваш .svelte
компонент, импортируйте store.js
import {stocks, update} from './store.js'
import {onMount} from 'svelte'
update('AAPL', {ask: 10, bid: 20})
update('MSFT', {ask: 10, bid: 20})
onMount(() => {
setTimeout(() => update('AAPL', {ask: 10.20, bid: 10.25}), 2000)
setTimeout(() => update('AAPL', {ask: 10.30, bid: 10.35}), 4000)
})
<!-- use dollar sign in front of store name to make svelte auto-subscribe -->
{JSON.stringify($stocks, null, 2)}