[英]Rendering nested objects in Svelte
JSON 文件如下所示。 您可以在https://api.mocki.io/v1/0f83a2e7找到整个 JSON 文件
{
"rows": [
{
"key": [
"0x1d42",
{
"x": 10.32,
"y": 11.13,
"z": 1.22
}
],
"value": {
"pos": {
"x": 10.32,
"y": 11.13,
"z": 1.22
},
"id16": "0x1d42",
"resultTime": "2021-02-21T23:28:03.558Z"
}
},
.......
]}
我想提取 values.pos,值。 id16,values.resulttime。 我尝试了下面的代码,但它没有给我任何结果。
<script>
import { onMount } from "svelte";
const apiURL = "https://api.mocki.io/v1/0f83a2e7";
let data = [];
onMount(async function() {
const response = await fetch(apiURL);
data = await response.json();
});
</script>
<pre>
<div>
{#each data.rows as row }
<div>
{#each row.value as value}
<p> {value.pos} </p>
{/each}
</div>
{/each}
</div>
</pre>
我如何提取这些值以便在表中显示它们?
首先要注意的是,在 Svelte 中, onMount
是在第一次渲染标记之后执行的(在onMount
期间它当然可以更新)这意味着你的组件的初始 state 必须能够在没有问题,它没有。
您尝试遍历data.rows
但此属性最初不存在,您可以通过使用属性行初始化数据来解决此问题: let data = { rows: [] }
然后您尝试遍历value
,但 value 不是数组,因此它无法循环遍历它。
另外value.pos
将是一个 object (x,y,z),所以当它最终呈现时,它只会在 output 中显示[Object object]
。
您只需直接指向它们即可提取这些值: <p>{row.value.pos.x}</p>
(目前还不完全清楚您要在这里做什么。)
也就是说,您可以使用await 块使代码更简单
<script>
const apiURL = "https://api.mocki.io/v1/0f83a2e7";
const load = url => fetch(url).then(res => res.json());
</script>
{#await load(apiURL) then data}
<pre>
<div>
{#each data.rows as row }
<div>
<p>{row.value.pos.x}</p>
<p>{row.value.pos.y}</p>
<p>{row.value.pos.z}</p>
</div>
{/each}
</div>
</pre>
{/await}
使用此代码,您可以等待渲染,直到您收到响应并且您知道data
将始终具有正确的格式
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.