gpt4 book ai didi

Svelte 商店未在屏幕上更新

转载 作者:行者123 更新时间:2023-12-04 10:46:40 25 4
gpt4 key购买 nike

我是 Svelte 的新手,犯了一个新手错误。我有一个到服务器的 websocket 连接,我正在记录数百条消息并将它们添加到商店,但页面根本没有更新。

App.svelte

<script>
import Socket from "./Socket.svelte"
import msgs from './stores'
</script>

<main>
<Socket items="{$msgs}"/>
</main>

Socket.svelte

<script>
export let items
</script>

{items.length}
{#if items}
{#each items as msg, i}
<p>{i} {msg}</p>
{/each}
{:else}
<p class="loading">waiting...</p>
{/if}

套接字.js

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

let msgs = []
const msgStore = readable(msgs)
export default msgStore

const socket = new WebSocket("ws://localhost:8080/socket");

socket.binaryType = "arraybuffer";

socket.onopen = function (event) {
msgs = [...msgs, "Connected"];
};

socket.onmessage = function (event) {
msgs = [...msgs, event];
console.log(msgs.length)

const msg = JSON.parse(event.data)
const msgType = msg.messageType
console.log(msgType)
};

在浏览器中,我得到了项目数组初始长度的 0,但它永远不会更新,即使消息在流动也是如此。

最佳答案

你实际上从来没有将任何东西插入 msgStore,只是 msgs 数组......这本身不是 react 性的。

在您的情况下最简单的是使用可写存储:

const msgs = []
export const msgStore = writable([])

socket.onmessage(e => {
...
msgs.push(msg)
msgStore.set(msgs)
})

您可以通过导出此的派生而不是可写存储来防止外部回火:

export const publicMsgStore = derived(msgStore, x => x)

或者,要通过一个可读存储一步完成,您需要它来包装您的整个逻辑:

export const msgStore = readable([], set => {
const msgs = []
...
socket.onmessage(e => {
...
msgs.push(msg)
set(msgs) // <= UPDATE THE STORE!!
})
})

您需要调用注入(inject)的 set 函数来更改可读存储的值(或通知它其值已更改)。

关于Svelte 商店未在屏幕上更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59675433/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com