⊗jsnxPmNvDL 48 of 57 menu

NextJSにおける動的リンク生成

ユーザーデータが含まれるファイルがあるとします:

export default users = [ { id: 1, name: 'name1', surn: 'surn1', }, { id: 2, name: 'name2', surn: 'surn2', }, { id: 3, name: 'name3', surn: 'surn3', }, ];

2つのコンポーネントを作成しましょう。 最初のコンポーネントは、詳細ページへのリンク付きで ユーザーリストを表示します。2番目のコンポーネントは その詳細な説明を表示します。

URL /users/listですべてのユーザーの リストが表示され、URL /users/show/:idで 特定のユーザーのIDが表示されるとします。

これには、以下のファイル構造を作成します:

  • /app/
    • /users/
      • users.js
      • /list/
        • page.jsx
      • /show/[id]/
        • page.jsx

最初のコンポーネントを作成し、ループ内で各ユーザーの idをリンクに動的に挿入します:

import users from '../users.js'; import Link from 'next/link'; export default function List() { let list = users.map(user => { return <li> <Link href={`/users/show/${user.id}`}> {user.name} </Link> </li>; }); return <ul> {list} </ul>; }

idに基づいて特定のユーザーを表示する コンポーネントを作成します:

import users from '../../users.js'; export default function User({params}) { let user = users[params.id]; return <div> <span>{user.id}</span> <span>{user.name}</span> <span>{user.surn}</span> </div>; }

以下の配列があります:

let prods = [ { id: 1, name: 'prod1', cost: 100, desc: 'desc1', }, { id: 2, name: 'prod2', cost: 200, desc: 'desc2', }, { id: 3, name: 'prod3', cost: 300, desc: 'desc3', }, ];

2つのコンポーネントを作成してください。 最初のコンポーネントは、製品の詳細ページへのリンク付きで 製品リストを表示します。2番目のコンポーネントは 製品の詳細な説明を表示します。

URLで存在しない製品のIDが渡された場合、 画面に404エラーが表示されるようにしてください。

日本語
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItalianoქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
当サイトでは、サイトの動作、分析、パーソナライゼーションのためにクッキーを使用しています。 データ処理はプライバシーポリシーに従って行われます。
すべて受け入れる 設定 拒否