検索

ホームページ  >  に質問  >  本文

Nuxt 3 スクリプト設定タグの if ステートメントの useAsyncData にアクセスできないのはなぜですか?

<p>Prismic API を使用して、Nuxt3 テンプレートに表示したいデータを取得しています。 </p><p> すべて正常に動作します。データがないときに 500 エラーではなく 404 ページを表示したいだけです。データが空かどうかを確認するチェックを追加しました: </p> <pre class="brush:html;toolbar:false;"><スクリプトのセットアップ> const ルート = useRoute() const 名 = ルート.params.werke; const { クライアント } = usePrismic() const { data: werk } = await useAsyncData('werk', () => client.getByUID("werk", name)) if (!werk.uid) { throw createError({ statusCode: 404, statusMessage: 'ページが見つかりません' }) } </スクリプト> </pre> <p>問題は、<code>if (!werk.uid)</code> セクションの werk.uid が常に空であることです。そのため、常に 404 エラーが発生します。私のテンプレートでは werk.uid が空ではないので、if ステートメントが useAsyncData を使用して const 変数にアクセスできないという問題があると思います。 </p> <p>何かアイデアはありますか?公式ドキュメントでも同様の方法が推奨されていました: https://v3.nuxtjs.org/getting-started/error-handling/#example-1</p>
P粉105971514P粉105971514497日前576

全員に返信(1)返信します

  • P粉752479467

    P粉7524794672023-08-27 00:26:14

    Prism フォーラムの誰かが解決策を見つけるのを手伝ってくれました。これは Vue 3 固有の問題です:

    werk の後に .value を使用する必要があります: (!werk.value)(werk.anything)

    だけではありません

    返事
    0
  • キャンセル返事