⊗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', }, ];

มาสร้างสองคอมโพเนนต์กัน คอมโพเนนต์แรกจะแสดงรายชื่อผู้ใช้พร้อมลิงก์ไปยังรายละเอียดของพวกเขา คอมโพเนนต์ที่สองจะแสดงรายละเอียดเหล่านั้น

กำหนดให้ 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', }, ];

สร้างสองคอมโพเนนต์ ให้คอมโพเนนต์แรกแสดงรายการผลิตภัณฑ์ในรูปแบบของลิงก์ไปยังคำอธิบายเต็มของผลิตภัณฑ์ ให้คอมโพเนนต์ที่สองแสดงคำอธิบายรายละเอียดของผลิตภัณฑ์

ทำให้แน่ใจว่า ถ้า 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
เราใช้คุกกี้สำหรับการทำงานของเว็บไซต์ การวิเคราะห์ และการปรับเนื้อหาให้เหมาะสมส่วนบุคคล การประมวลผลข้อมูลเกิดขึ้นตาม นโยบายความเป็นส่วนตัว.
ยอมรับทั้งหมด ปรับแต่ง ปฏิเสธ