✍️2️⃣ توضیح روشهای ۴ تا ۶ صفحهبندی (Pagination) در API
✍️2️⃣ توضیح روشهای ۴ تا ۶ صفحهبندی (Pagination) در API
4️⃣ روش Time-Based Pagination
وقتی دادههامون به ترتیب زمان ثبت میشن (مثلاً رویدادهای یک سیستم لاگ یا خبرنامههای زنده)، میتونیم با استفاده از پارامترهایی مثل since و until بازهی زمانی دلخواهمون رو مشخص کنیم.
مثال:
GET /events?since=2025-01-01&until=2025-01-10
اینجا API رو طوری طراحی میکنیم که همهی رویدادهایی که بین اول تا دهم ژانویه اتفاق افتاده رو برگردونه.
وقتی دادهها به ترتیب زمان ثبت میشن، این روش خیلی منطقی و طبیعیه؛ و برای استفاده، فهم سادهای داره؛ ولی اگه چند رویداد دقیقا در یک بازه زمانی یکسان ثبت بشن، ممکنه با ترتیب دقیق برگردونده نشه. همچنین اگر بازهی زمانی خیلی گسترده باشه، ممکنه تعداد زیادی رکورد برگرده که میتونه روی پرفرمنس تاثیر منفی بذاره.
5️⃣ روش Hypermedia (HATEOAS) Links
روش HATEOAS (Hypermedia As The Engine Of Application State) یکی از اصول کلیدی REST هست. توی این روش، پاسخهای API شامل لینکهایی به صفحات بعدی یا قبلی هستند. این لینکها معمولاً در هدر یا بدنهی پاسخ قرار میگیرند و به کلاینت میگن «برای ادامه اینجا رو ببین» یا «صفحه قبلی اینجاست».
مثال:
Link: ; rel="next", ; rel="prev"
توی این مثال، لینکهای next و prev به کلاینت کمک میکنن بدون اینکه خودشون URL ها رو بسازن، به صفحات بعدی یا قبلی دسترسی پیدا کنن.
بزرگترین مزیتش علاوه بر استاندارد بودن، اینه که کلاینتها نیازی به دونستن ساختار URLها ندارن؛ API خودش مسیر بعدی رو بهشون میگه. در ضمن به راحتی میشه لینکهای مختلف (مثلاً first، last، یا حتی لینکهای مرتبط) رو اضافه کرد.از طرفی مدیریت و تولید این لینکها به دقت نیاز داره تا همهی روابط درست تعریف بشه؛ و استفاده از هدرهای HTTP اضافی ممکنه برای برخی کلاینتها و ابزارها پیچیده باشه.
6️⃣ روش Metadata in Responses
توی این روش، به جای ارسال اطلاعات صفحهبندی در هدر، کل متادیتا (مثل تعداد کل رکوردها، cursor بعدی، و وضعیت وجود صفحهی بعدی) رو توی بدنهی پاسخ JSON میگنجونیم. این کار باعث میشه کلاینت به راحتی اطلاعات لازم رو از یک جا دریافت کنه.
{
"data": [...],
"pagination": {
"total": 1000,
"next_cursor": "def456",
"has_more": true
}
}
اینجا کلاینت علاوه بر دادههای اصلی، اطلاعات کاملی از وضعیت صفحهبندی دریافت میکنه. خوبیش اینه که همهی اطلاعات مورد نیاز برای صفحهبندی توی یک JSON مشخص هستن و خوانایی بالایی هم داره چون ساختار JSON معمولاً برای توسعهدهندهها آشنا و راحته. ولی از اون سمت اضافه کردن متادیتا ممکنه حجم پاسخ رو کمی بیشتر کنه. همچنین با استانداردهای هدر HTTP در تضاده؛ یعنی برخی استانداردهای REST ترجیح میدن اطلاعات مربوط به ناوبری در هدر قرار بگیره، اگرچه این موضوع بیشتر یک نکته سبکسازیه تا یک مشکل جدی.
💬 نظر؟ بریم سراغ موضوع دیگه: 🤓
یا روی API Design ادامه بدیم: ⚙️
اگر روی API Design بمونیم:
- موضوع API Documentation و Discoverability
- استراتژیهای مدیریت نسخهبندی API در طول زمان (API Evolution)