繁体   English   中英

在 Svelte 中渲染嵌套对象

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM