无法从 SvelteKit 中的 API 获取数据

ana*_*rki 5 javascript fetch svelte sveltekit

我正在尝试通过从 API 获取来显示我请求的数据。除了获取之外,一切都运行良好。

这是我的组件,名为Items.svelte

<script>
  let items = [];

  async function load({ fetch }) {
    const url = "../r/api/items/all";
    let res = await fetch(url);

    if (res.ok) {
      return {
        props: {
          items: await res.json(),
        },
      };
    }
    return {
      status: res.status,
      error: new Error(),
    };
  }
</script>

{#each items as item}
  <header>
    <h2>{item.title}</h2>
    <p>{item.body}</p>
  </header>
{/each}

Run Code Online (Sandbox Code Playgroud)

这是App.svelte

<script>
  import Items from '$lib/Items.svelte';
</script>
    
<Items /> 
Run Code Online (Sandbox Code Playgroud)

我究竟做错了什么?

Akq*_*ira 6

根据文档 ---> https://kit.svelte.dev/docs/loading

您缺少context="module"脚本部分。它应该是 :

<script context="module">
    export async function load({ fetch }) {
        let res = await fetch('../r/api/items/all');

        if (res.ok) {
            return {
                props: {
                    items: await res.json()
                }
            };
        }
        return {
            status: res.status,
            error: new Error()
        };
    }
</script>


<script>
    export let items = []
</script>    

{#each items as item}
    <header>
        <h2>{item?.title}</h2>
        <p>{item?.body}</p>
    </header>
{/each}
Run Code Online (Sandbox Code Playgroud)

  • 这意味着它没有到达您自己的 json。一个技巧是使用 hooks.js (或 ts)并实现函数handle({request,resolve})来console.log请求和响应。这对于准确了解幕后发生的事情有很大帮助 (2认同)