شروع دوره آزمایشی رایگان
EnglishEnglish
EspañolSpanish
简体中文Chinese
繁體中文Chinese (Traditional)
FrançaisFrench
DeutschGerman
日本語Japanese
PortuguêsPortuguese
ItalianoItalian
한국어Korean
РусскийRussian
NederlandsDutch
العربيةArabic
PolskiPolish
हिन्दीHindi
Tiếng ViệtVietnamese
SvenskaSwedish
ΕλληνικάGreek
TürkçeTurkish
ไทยThai
ČeštinaCzech
RomânăRomanian
MagyarHungarian
УкраїнськаUkrainian
IndonesiaIndonesian
DanskDanish
SuomiFinnish
БългарскиBulgarian
עבריתHebrew
NorskNorwegian
HrvatskiCroatian
CatalàCatalan
SlovenčinaSlovak
LietuviųLithuanian
SlovenščinaSlovenian
СрпскиSerbian
EestiEstonian
LatviešuLatvian
فارسیPersian
മലയാളംMalayalam
தமிழ்Tamil
اردوUrdu
Searching...
SoBrief
سیستم‌های هایپرمدیا
Amazon Kindle Audible
۳ روز دسترسی کامل رایگان
قفل گوش دادن و امکانات بیشتر را باز کنید!
ادامه

نکات کلیدی

۱. ابررسانه: معماری قدرتمند و کمتر شناخته‌شده

کنترل‌های ابررسانه همان چیزی است که ابررسانه را از سایر انواع رسانه متمایز می‌کند.

فراتر از اسناد. ابررسانه صرفاً به اسناد پیوندی مانند صفحات HTML محدود نمی‌شود. این یک معماری سیستمی است که رسانه‌ها شامل کنترل‌هایی مانند لینک‌ها و فرم‌ها هستند و امکان تعامل و ناوبری غیرخطی را فراهم می‌آورند. این فراتر از مصرف منفعل است و سیستم‌های پویا را ممکن می‌سازد.

اجزای سیستم. یک سیستم ابررسانه کامل شامل چندین بخش است که با هم کار می‌کنند:

  • قالب ابررسانه (HTML، HXML)
  • پروتکل شبکه (HTTP)
  • سروری که API ابررسانه ارائه می‌دهد
  • کلاینتی که ابررسانه را تفسیر می‌کند (مرورگر وب، کلاینت Hyperview)
    قدرت این سیستم در یکپارچگی این اجزا نهفته است، نه فقط در قالب آن.

اهمیت امروزی. با وجود گستردگی ابررسانه در وب، این مفهوم معماری اغلب نادیده گرفته می‌شود، به‌ویژه توسط توسعه‌دهندگانی که روی فریم‌ورک‌های سمت کلاینت تمرکز دارند. درک کامل این سیستم، پتانسیل آن را برای ساخت برنامه‌های مقاوم و انعطاف‌پذیر آشکار می‌کند.

۲. REST به معنای ابررسانه است، نه فقط JSON

اگر موتور وضعیت برنامه (و در نتیجه API) توسط ابرمتن هدایت نشود، نمی‌تواند RESTful باشد و API REST محسوب نمی‌شود. همین.

تعریف فیلدینگ. روی فیلدینگ، که اصطلاح REST را ابداع کرد، معماری وب اواخر دهه ۱۹۹۰ را توصیف کرد که توسط HTML و HTTP هدایت می‌شد. یکی از محدودیت‌های اصلی REST، «رابط یکنواخت» است که شامل «ابررسانه به عنوان موتور وضعیت برنامه» (HATEOAS) می‌شود.

توضیح HATEOAS. این بدان معناست که پاسخ ابررسانه‌ای (مانند HTML) باید تمام اطلاعات لازم برای درک اقدامات و انتقال‌های ممکن توسط کلاینت را در خود داشته باشد.

  • لینک‌های HTML (<a>) و فرم‌ها (<form>) کنترل‌های ابررسانه‌ای هستند.
  • آن‌ها وضعیت‌های بعدی ممکن (آدرس‌ها و متدها) را مستقیماً رمزگذاری می‌کنند.
  • کلاینت (مرورگر) نیازی به دانش قبلی از ساختار API ندارد.

APIهای JSON متفاوت‌اند. بیشتر APIهای مدرن JSON فاقد کنترل‌های ابررسانه‌ای هستند. آن‌ها داده‌های خام بازمی‌گردانند و کلاینت باید از پیش بداند چه آدرس‌ها و متدهایی را باید فراخوانی کند. این وابستگی شدید آن‌ها را به APIهای داده تبدیل می‌کند، نه APIهای RESTful ابررسانه‌ای، هرچند اصطلاح «REST» به اشتباه در صنعت رایج است.

۳. برنامه‌های وب ۱.۰ از پیش مبتنی بر ابررسانه بودند

حتی امروز، در دنیای توسعه وب که فریم‌ورک‌های بزرگ جاوااسکریپت محور غالب شده‌اند، بسیاری ترجیح می‌دهند از HTML ساده برای رسیدن به اهداف برنامه خود استفاده کنند و معمولاً از نتایج راضی‌اند.

ساده و قدرتمند. برنامه‌های وب اولیه، که به «وب ۱.۰» یا «برنامه‌های چندصفحه‌ای» (MPA) معروف‌اند، عمدتاً با لینک‌ها و فرم‌های HTML ساخته شده بودند. این دو کنترل ابررسانه‌ای همراه با HTTP، امکانات دینامیکی گسترده‌ای فراهم می‌کردند.

مکانیک اصلی:

  • لینک‌ها (<a>) درخواست‌های HTTP GET را برای ناوبری فعال می‌کنند.
  • فرم‌ها (<form>) درخواست‌های HTTP GET یا POST را برای ارسال داده و تغییر وضعیت فعال می‌کنند.
  • سرور با HTML جدید پاسخ می‌دهد و کل صفحه را جایگزین می‌کند.

طبیعتاً RESTful. این برنامه‌ها به طور طبیعی اصول REST را رعایت می‌کردند. مرورگر به عنوان کلاینت ابررسانه، کنترل‌های HTML را تفسیر می‌کرد تا با سرور تعامل داشته باشد. این رویکرد ساده، مقاوم و بسیار انعطاف‌پذیر نسبت به تغییرات سمت سرور بود.

۴. SPAها و APIهای JSON: مسیری متفاوت و اغلب پیچیده‌تر

برنامه‌هایی که به این سبک ساخته می‌شوند، مبتنی بر ابررسانه نیستند و از سیستم ابررسانه‌ای وب بهره نمی‌برند.

ظهور SPAها. نیاز به تجربه‌های کاربری تعاملی‌تر باعث محبوبیت برنامه‌های تک‌صفحه‌ای (SPA) شد. SPAها با استفاده از جاوااسکریپت، رابط کاربری را در یک صفحه به‌روزرسانی می‌کنند و از بارگذاری کامل صفحه جلوگیری می‌کنند.

تغییر معماری. این رویکرد معمولاً شامل:

  • ساخت رابط کاربری و مدیریت وضعیت عمدتاً در جاوااسکریپت سمت کلاینت (مانند React، Vue)
  • ارتباط با سرور از طریق فراخوانی‌های AJAX و تبادل داده JSON
  • تبدیل HTML به هدف رندرینگ و از دست دادن نقش ابررسانه‌ای آن

پیچیدگی بیشتر. در حالی که UIهای غنی را ممکن می‌سازد، SPAها اغلب پیچیدگی قابل توجهی ایجاد می‌کنند:

  • مدیریت وضعیت سمت کلاینت و همگام‌سازی با سرور
  • پیاده‌سازی مسیریابی و منطق رندرینگ سمت کلاینت
  • مواجهه با «خستگی جاوااسکریپت» به دلیل ابزارها و وابستگی‌های پیچیده
    این معماری شبیه مدل‌های کلاینت ضخیم قدیمی است و از سیستم ابررسانه‌ای بومی وب فاصله می‌گیرد.

۵. Htmx: گسترش HTML برای برنامه‌های ابررسانه‌ای مدرن

Htmx یک کتابخانه جاوااسکریپت است که HTML را دقیقاً به این شکل گسترش می‌دهد و موضوع چند فصل بعدی این کتاب خواهد بود.

پل زدن شکاف. Htmx کتابخانه‌ای کوچک و بدون وابستگی است که HTML را به عنوان یک ابررسانه گسترش می‌دهد. این امکان را به توسعه‌دهندگان می‌دهد تا رابط‌های کاربری تعاملی مدرن بسازند بدون اینکه معماری ابررسانه‌ای وب را رها کنند.

مبتنی بر ابررسانه. Htmx از جاوااسکریپت برای جایگزینی HTML استفاده نمی‌کند، بلکه قابلیت‌های آن را تقویت می‌کند. این کتابخانه محدودیت‌های HTML ساده را با امکان:

  • فعال‌سازی درخواست‌های HTTP توسط هر عنصر
  • فعال‌سازی درخواست‌ها توسط هر رویداد DOM
  • دسترسی به تمام متدهای HTTP (GET، POST، PUT، PATCH، DELETE)
  • به‌روزرسانی بخش‌های خاص صفحه (ترانزکلوژن) به جای بارگذاری کامل صفحه
    رفع می‌کند.

رویکرد اعلامی. Htmx این کار را از طریق مجموعه‌ای از ویژگی‌های HTML با پیشوند hx- انجام می‌دهد. این باعث می‌شود تعریف رفتار نزدیک به عنصر HTML باشد و «محلی بودن رفتار» را بر جداسازی سخت مسئولیت‌ها ترجیح دهد.

۶. ویژگی‌های اعلامی، تعاملات Htmx را قدرتمند می‌کنند

Htmx HTML را به عنوان یک ابررسانه گسترش می‌دهد و طراحی شده تا این گسترش تا حد امکان طبیعی و سازگار با مفاهیم موجود HTML باشد.

مبتنی بر ویژگی‌ها. عملکرد اصلی Htmx از طریق ویژگی‌های اعلامی HTML ارائه می‌شود که شبیه به کنترل‌های بومی HTML مانند href و action است. این باعث می‌شود Htmx به عنوان توسعه‌ای طبیعی از زبان HTML احساس شود.

ویژگی‌های کلیدی:

  • hx-get، hx-post، hx-put، hx-patch، hx-delete: مشخص کردن متد HTTP و آدرس URL برای درخواست فعال‌شده توسط عنصر
  • hx-trigger: تعریف رویداد(های) DOM که درخواست را آغاز می‌کنند (مقدار پیش‌فرض بسته به عنصر متفاوت است)
  • hx-target: مشخص کردن عنصری که محتوای آن توسط پاسخ به‌روزرسانی می‌شود
  • hx-swap: کنترل نحوه جایگزینی یا تعامل محتوای پاسخ با محتوای عنصر هدف (مثلاً innerHTML، outerHTML، afterbegin)

ساده و قدرتمند. این ویژگی‌ها امکان تعاملات پیچیده‌ای مانند به‌روزرسانی‌های درون‌خطی، جستجوی فعال و بارگذاری تنبل را با حداقل یا بدون کد جاوااسکریپت امری فراهم می‌کنند. رفتار مستقیماً روی عنصر تعریف می‌شود که خوانایی و نگهداری را بهبود می‌بخشد.

۷. بهره‌گیری از هدرها و رویدادهای HTTP برای رابط‌های پویا

Htmx از این ویژگی HTTP بهره می‌برد و هدرهای اضافی و در نتیجه زمینه بیشتری به درخواست‌های HTTP خود اضافه می‌کند.

ارتباط پیشرفته. Htmx ارتباط استاندارد HTTP بین کلاینت و سرور را گسترش می‌دهد. هدرهای خاصی مانند HX-Request و HX-Trigger را اضافه می‌کند تا زمینه‌ای درباره درخواست AJAX به سرور ارائه دهد.

کنترل سمت سرور. سرور می‌تواند این هدرها را بخواند تا:

  • تشخیص دهد آیا درخواست از Htmx است یا ناوبری معمولی مرورگر
  • فقط قطعات HTML مورد نیاز برای به‌روزرسانی را به صورت شرطی رندر کند
  • منطق متفاوتی بر اساس عنصر یا رویداد فعال‌کننده پیاده‌سازی کند

معماری مبتنی بر رویداد. Htmx همچنین رویدادهای سفارشی را منتشر و گوش می‌دهد:

  • رویدادهایی در طول چرخه درخواست مانند htmx:configRequest و htmx:afterRequest فعال می‌کند
  • سرور می‌تواند رویدادهای سمت کلاینت را از طریق هدر پاسخ HX-Trigger فعال کند
  • این امکان به‌روزرسانی‌های جداشده و تعاملات پیچیده بین عناصر مختلف صفحه را فراهم می‌آورد.

۸. اسکریپت‌نویسی، تقویت‌کننده است نه جایگزین ابررسانه

هدف Htmx کاهش کد نیست، بلکه کدی خواناتر و سازگارتر با ابررسانه است.

اسکریپت‌نویسی مجاز است. روی فیلدینگ اشاره کرده که REST اجازه کد بر حسب تقاضا (اسکریپت‌نویسی) را می‌دهد. در برنامه‌های ابررسانه‌ای، اسکریپت‌نویسی خوش‌آمد است اما باید مدل ابررسانه را تقویت کند، نه جایگزین آن.

محدودیت‌های اسکریپت‌نویسی سازگار با ابررسانه:

  • قالب اصلی داده‌های مبادله شده همچنان ابررسانه (HTML/HXML) باقی می‌ماند.
  • وضعیت سمت کلاینت خارج از DOM به حداقل می‌رسد.

ابزارهای مناسب. چند گزینه اسکریپت‌نویسی با این فلسفه همسو هستند:

  • VanillaJS (جاوااسکریپت ساده) ساختار یافته با اصولی مانند محلی بودن رفتار (LoB) و ویژگی‌های داده (RSJS)
  • Alpine.js: کتابخانه‌ای برای افزودن رفتار مستقیم در HTML با اتصال داده واکنشی
  • _hyperscript: زبانی طراحی شده همراه با Htmx، متمرکز بر دستکاری DOM مبتنی بر رویداد با نحو شبیه زبان انگلیسی

تمرکز بر تعامل. اسکریپت‌نویسی در برنامه‌های ابررسانه‌ای بهترین کاربرد را در طراحی تعامل (انیمیشن‌ها، منطق محلی UI) دارد، در حالی که منطق کسب‌وکار و ارائه در سرور باقی می‌ماند. این سرور را به منبع حقیقت تبدیل می‌کند و کلاینت را ساده‌تر می‌سازد.

۹. APIهای داده JSON نیازهای متفاوتی نسبت به APIهای ابررسانه دارند

APIهای JSON ده سال پس از REST به عنوان ابزاری رایج در توسعه وب ظاهر شدند؛ REST درباره ابررسانه و نسخه ۱.۰ وب بود.

اهداف متفاوت. در حالی که API ابررسانه‌ای (مانند HTML روی HTTP) برای تعامل با کلاینت ابررسانه‌ای (مانند مرورگر) ایده‌آل است، APIهای داده JSON برای موارد استفاده متفاوتی طراحی شده‌اند.

موارد استفاده APIهای JSON:

  • برنامه‌های موبایل (به‌ویژه غیر Hyperview)
  • اسکریپت‌های خودکار و پردازش داده‌های حجیم
  • یکپارچه‌سازی‌های شخص ثالث و همگام‌سازی داده‌ها

نیازهای متمایز. APIهای JSON معمولاً به:

  • ثبات و نسخه‌بندی (کلاینت‌ها به ساختار وابسته‌اند)
  • محدودیت نرخ و مکانیزم‌های احراز هویت قوی (معمولاً مبتنی بر توکن)
  • نقاط انتهایی عمومی برای نیازهای داده‌ای گسترده
    نیاز دارند.

تکامل جداگانه. جدا نگه داشتن APIهای داده JSON از API ابررسانه‌ای اجازه می‌دهد هرکدام بر اساس نیازهای خود تکامل یابند. API ابررسانه‌ای می‌تواند برای UI برنامه تخصصی باشد، در حالی که API داده برای کلاینت‌های برنامه‌نویسی متنوع پایدار باقی می‌ماند.

۱۰. ابررسانه برای موبایل هم کار می‌کند: معرفی Hyperview

ابررسانه یک مفهوم کلی است و می‌تواند در همه انواع پلتفرم‌ها و برنامه‌ها به کار رود.

چالش‌های موبایل. توسعه سنتی موبایل بومی معمولاً به معماری کلاینت ضخیم منجر می‌شود که منطق در کلاینت و سرور پراکنده است، مشابه SPAها. این باعث پیچیدگی کد و مشکلات تغییر API می‌شود.

راه‌حل ابررسانه‌ای. به‌کارگیری معماری ابررسانه در موبایل راه‌حلی ارائه می‌دهد. سرور کنترل وضعیت برنامه را در دست دارد، کلاینت ساده می‌شود و مشکلات نسخه‌بندی API برطرف می‌گردد.

سیستم Hyperview. Hyperview یک سیستم ابررسانه‌ای مخصوص موبایل است که شامل:

  • HXML: قالب ابررسانه‌ای مبتنی بر XML برای تعریف رابط‌های موبایل
  • کلاینت Hyperview: کلاینت موبایل بومی (React Native) که HXML را رندر می‌کند

فراتر از وب‌ویوها. در حالی که جاسازی وب‌ویو ساده است، نمی‌تواند الگوهای UX بومی موبایل (ناوبری، ژست‌ها) را به خوبی بازتولید کند. Hyperview برای نمایش این الگوها به صورت بومی طراحی شده است.

۱۱. HXML و رفتارها: تعاملات ابررسانه‌ای بومی موبایل

HXML طوری طراحی شده که برای توسعه‌دهندگان وب که با HTML آشنا هستند، حس آشنایی داشته باشد.

قالب مبتنی بر XML. HXML از نحو XML مشابه HTML استفاده می‌کند که برای توسعه‌دهندگان وب قابل دسترس و با قالب‌سازی سمت سرور سازگار است. شامل عناصری برای الگوهای رایج UI موبایل مانند فهرست‌ها (<list>, <item>) و ورودی‌ها (<text-field>, <select-single>) است.

رفتارها برای تعامل. تعاملات HXML با استفاده از عناصر <behavior> تعریف می‌شوند که محرک‌ها و اقدامات را از هم جدا می‌کنند:

  • trigger: تعامل کاربر (مثلاً press، longPress، visible، refresh)
  • action: عملیات نتیجه (مثلاً push، back، replace-inner، append، alert، share)
  • href: آدرس URL برای اقداماتی که نیاز به محتوای جدید دارند
  • target: شناسه عنصری که برای به‌روزرسانی تغییر می‌کند

الگوهای بومی. رفتارها امکان تعاملات خاص موبایل مانند:

  • ناوبری مبتنی بر پشته (push، back، new، close)
  • کشیدن برای تازه‌سازی (refresh trigger)
  • پیمایش بی‌نهایت (visible trigger، append action)
    را فراهم می‌کنند.

قابلیت توسعه. HXML و کلاینت Hyperview طوری طراحی شده‌اند که با عناصر و اقدامات سفارشی قابل گسترش باشند و توسعه‌دهندگان بتوانند ویژگی‌های منحصر به فرد اضافه کنند بدون نیاز به اسکریپت‌نویسی امری برای منطق اصلی.

۱۲. برنامه‌های ابررسانه‌ای، قدرت و سادگی سمت سرور را به حداکثر می‌رسانند

یکی از مزایای بزرگ رویکرد مبتنی بر ابررسانه این است که محیط سمت سرور را هنگام ساخت برنامه وب بسیار مهم‌تر می‌کند.

سرور به عنوان هسته. در برنامه‌های ابررسانه‌ای، سرور موتور اصلی وضعیت برنامه و منطق ارائه است. این از بلوغ و قدرت محیط‌های سمت سرور بهره می‌برد.

مزایای تمرکز بر سرور:

  • دسترسی به موتورهای قالب‌سازی

آخرین بروزرسانی:

Report Issue

خلاصه نقدها

4.37 از 5
میانگین ۲۲۵ امتیاز از Goodreads و Amazon.

کتاب «سامانه‌های ابررسانه» عمدتاً با بازخوردهای مثبت مواجه شده است و خوانندگان از رویکرد بازگشت به اصول پایه در توسعه وب استقبال می‌کنند. بسیاری از نقدهای کتاب بر چارچوب‌های مدرن تمرکز دارد و در عین حال، ترویج استفاده از HTMX و برنامه‌های مبتنی بر ابررسانه را ستایش می‌کنند. مفاهیم مطرح‌شده در کتاب برای خوانندگان تازگی دارد و کاربردی بودن آن‌ها در موقعیت‌های واقعی مورد تأیید است. برخی انتقادات به پیچیدگی برنامه‌های بزرگ‌تر و نگرانی‌هایی درباره تفکیک مسئولیت‌ها اشاره دارد. بخش توسعه موبایل نیز واکنش‌های متفاوتی را به همراه داشته است. در مجموع، این کتاب به عنوان اثری تأمل‌برانگیز و با پتانسیل ایجاد تغییرات بنیادین در حوزه توسعه وب شناخته می‌شود.

Your rating:
4.66
158 امتیاز
Want to read the full book?

سؤالات متداول

What is Hypermedia Systems by Carson Gross about?

  • Core focus: The book explores how hypermedia, traditionally seen as document-centric, can serve as a powerful foundation for building modern, interactive web and mobile applications.
  • Architectural emphasis: It highlights the full hypermedia architecture—covering HTML, HTTP, servers, and clients—and how these components interact to create flexible, RESTful applications.
  • Modern relevance: Carson Gross argues that hypermedia-driven applications (HDAs) are not legacy but a sophisticated, competitive alternative to Single Page Applications (SPAs).
  • Practical demonstration: The book uses real-world examples, such as building a contact management app, to ground its concepts in practical code.

Why should I read Hypermedia Systems by Carson Gross?

  • Clarifies misconceptions: The book dispels the myth that hypermedia is outdated, showing its relevance for dynamic, complex applications.
  • Practical guidance: It provides hands-on examples and step-by-step tutorials, including building and enhancing a contact management app with htmx and porting it to mobile with Hyperview.
  • Alternative to SPAs: Gross presents hypermedia as a simpler, more maintainable, and secure alternative to heavy JavaScript frameworks and SPAs.
  • Focus on simplicity: The book demonstrates how server-driven UI and minimal client-side scripting can reduce complexity and improve maintainability.

What are the key takeaways from Hypermedia Systems by Carson Gross?

  • Hypermedia as modern architecture: Hypermedia is a robust, flexible, and modern approach to building web and mobile applications, not just a legacy technology.
  • RESTful principles matter: True RESTful systems require hypermedia controls (HATEOAS), which many JSON APIs lack, leading to tighter coupling and more brittle applications.
  • Tools for enhancement: Libraries like htmx and Hyperview can bring SPA-like interactivity to hypermedia-driven apps without sacrificing simplicity or RESTful design.
  • Incremental improvement: Applications can be enhanced step-by-step, adding interactivity and advanced UI patterns while preserving the core hypermedia architecture.

How does Hypermedia Systems by Carson Gross define a hypermedia system and its components?

  • RESTful foundation: A hypermedia system adheres to REST as described by Roy Fielding, using hypermedia controls to enable non-linear, dynamic interactions.
  • Key components: It includes hypermedia formats (like HTML or HXML), network protocols (HTTP), servers presenting hypermedia APIs, and clients (browsers or mobile apps) that interpret responses.
  • Distinction from JSON APIs: The book stresses that many so-called REST APIs are not truly RESTful unless they include hypermedia controls for navigation and interaction.
  • Loose coupling: Hypermedia systems embed all necessary interaction information in responses, reducing the need for clients to have prior knowledge of the API.

How do Hypermedia-Driven Applications (HDAs) differ from Single Page Applications (SPAs) according to Carson Gross?

  • Architectural contrast: HDAs use hypermedia as the engine of application state, exchanging HTML (or HXML) over HTTP, while SPAs rely on JavaScript and JSON APIs.
  • Coupling and flexibility: HDAs avoid tight client-server coupling by embedding interaction logic in hypermedia, whereas SPAs require clients to know API structures in advance.
  • User experience trade-offs: SPAs offer richer interactivity but introduce complexity and “JavaScript Fatigue,” while HDAs provide simplicity, robustness, and leverage browser features like caching.
  • Maintainability: HDAs are more tolerant of API changes and easier to maintain due to their reliance on self-descriptive hypermedia responses.

What is htmx and how does it enhance HTML for building Hypermedia-Driven Applications, as described in Hypermedia Systems?

  • Attribute-driven AJAX: htmx extends HTML with attributes (e.g., hx-get, hx-post, hx-trigger, hx-swap, hx-target) to declaratively specify AJAX requests and DOM updates without writing JavaScript.
  • Overcoming HTML limitations: It allows any element to issue any HTTP method, be triggered by any event, and update parts of the page dynamically, addressing native HTML’s limited interactivity.
  • Advanced features: htmx supports event filtering, request synchronization, out-of-band swaps, and CSS transition integration for smooth, dynamic UIs.
  • Progressive enhancement: htmx preserves and extends HTML as hypermedia, enabling modern interactivity while maintaining RESTful and progressive enhancement principles.

How does Hypermedia Systems by Carson Gross explain REST and HATEOAS in the context of hypermedia?

  • REST constraints: The book reviews Fielding’s REST constraints, emphasizing statelessness, caching, layered systems, and especially the uniform interface with hypermedia as the engine of application state (HATEOAS).
  • Self-descriptive messages: RESTful responses must include all information (hypermedia controls) necessary for clients to navigate and interact without prior knowledge of the API.
  • HATEOAS benefits: Hypermedia responses dynamically encode available actions, enabling clients to adapt to API changes without breaking, reducing versioning headaches common in JSON APIs.
  • Loose coupling: This approach allows for more flexible, evolvable systems where clients and servers can change independently.

What practical example does Carson Gross use in Hypermedia Systems to demonstrate hypermedia-driven development?

  • Contact.app: The book features a simple contact management web application built with Python, Flask, and Jinja2 templates, demonstrating CRUD operations using pure HTML hypermedia controls.
  • Incremental enhancement: It shows how to progressively add interactivity with htmx, such as AJAX navigation, inline deletes, active search, lazy loading, and progress indicators.
  • Educational value: This example grounds theoretical concepts in practical code, illustrating how hypermedia-driven applications can be built and improved step by step.
  • Mobile extension: The app is also ported to mobile using Hyperview, demonstrating hypermedia’s versatility across platforms.

What are the key concepts of hypermedia-friendly scripting discussed in Hypermedia Systems?

  • Scripting constraints: Scripting in HDAs should keep the main data format as hypermedia and minimize client-side state outside the DOM, ensuring business and presentation logic remain server-side.
  • Scripting tools: The book covers Vanilla JavaScript (structured with RSJS), Alpine.js (declarative and reactive), and _hyperscript (English-like syntax focused on event handling) as compatible scripting options.
  • Locality of behavior: Emphasizes embedding behavior declarations close to the HTML elements they affect, improving readability and maintainability.
  • Contrast with traditional JS: This approach contrasts with the traditional separation of concerns, favoring proximity of markup and behavior for clarity.

How does Hypermedia Systems by Carson Gross apply hypermedia principles to native mobile app development with Hyperview?

  • HXML format: Hyperview uses HXML, an XML-based hypermedia format inspired by HTML, to represent mobile UI elements, layouts, inputs, and behaviors declaratively.
  • Client-server model: The Hyperview client (a React Native app) renders HXML screens fetched from the server, with all app logic and UI defined server-side, avoiding thick-client complexity.
  • Extensibility: Hyperview supports custom UI elements and behavior actions, enabling deep platform integration and rich interactions while preserving the hypermedia-driven architecture.
  • Consistency: This approach brings the benefits of hypermedia—loose coupling, flexibility, and maintainability—to native mobile development.

What advanced UI patterns and behaviors are implemented with htmx and Hyperview in Hypermedia Systems?

  • Active Search: Implements search-as-you-type with debounced AJAX requests updating search results dynamically, improving UX without custom JavaScript.
  • Lazy Loading: Defers loading expensive data (like total contact count) until needed, using htmx triggers for performance optimization.
  • Inline and Bulk Delete: Enables deleting contacts directly from lists with confirmation dialogs, smooth fade-out animations, and bulk operations, all declaratively via htmx or HXML attributes.
  • Mobile behaviors: Hyperview uses <behavior> elements to define triggers and actions (navigation, updates, system actions), enabling rich, decoupled mobile interactions.

What are the advantages and challenges of using Vanilla JavaScript and other scripting tools in Hypermedia-Driven Applications, according to Carson Gross?

  • Advantages: VanillaJS requires no additional libraries, reduces complexity compared to SPA frameworks, and can be structured effectively using RSJS guidelines for maintainability and locality of behavior.
  • Challenges: It lacks a default architectural style, can lead to “jQuery soup” with scattered event handlers, and DOM APIs are verbose and sometimes unintuitive.
  • Best practices: Using data- attributes to invoke behavior and organizing code per component/file improves clarity and reuse, aligning VanillaJS with hypermedia-friendly scripting principles.
  • Alternative tools: Alpine.js and _hyperscript offer more declarative, readable, and maintainable approaches for embedding behavior in hypermedia-driven apps.

What is the significance of Carson Gross’s message about the future of hypermedia in web development in Hypermedia Systems?

  • Hypermedia resurgence: The book argues that hypermedia is a “great idea” with tremendous untapped potential and deserves renewed attention in modern web development.
  • Call to action: Gross encourages developers to learn, build with, and advocate for hypermedia-driven architectures to challenge SPA dominance.
  • Philosophical inspiration: Quoting Terminator 2, “The future is not set. There is no fate but what we make for ourselves,” the book inspires readers to shape the future of web architecture by embracing hypermedia.
  • Vision for the web: The message is that developers have the power to create simpler, more robust, and maintainable systems by returning to and advancing hypermedia principles.

درباره نویسنده

کارسون گراس خالق HTMX و نویسنده‌ی کتاب «سامانه‌های ابررسانه‌ای» است. او به‌خاطر حمایت از برنامه‌های مبتنی بر ابررسانه و نقد روش‌های رایج توسعه وب معاصر شناخته شده است. گراس بر بازگشت به شیوه‌های ساده‌تر و کارآمدتر توسعه وب تأکید دارد که از قابلیت‌های ذاتی HTML و HTTP بهره می‌برند. آثار او بر گسترش توانمندی‌های HTML از طریق HTMX متمرکز است، رویکردی که به توسعه‌دهندگان امکان می‌دهد برنامه‌های وب پویا را با وابستگی کمتر به چارچوب‌های جاوااسکریپت ایجاد کنند. روش گراس بر رندرینگ سمت سرور و اصول معماری REST که نخستین بار توسط روی فیلدینگ مطرح شد، تأکید دارد. ایده‌های او در میان توسعه‌دهندگانی که به دنبال جایگزین‌هایی برای چارچوب‌های پیچیده‌ی فرانت‌اند هستند، مورد توجه قرار گرفته است.

دانلود PDF

To save this سیستم‌های هایپرمدیا summary for later, download the free PDF. You can print it out, or read offline at your convenience.
Download PDF

دانلود EPUB

To read this سیستم‌های هایپرمدیا summary on your e-reader device or app, download the free EPUB. The .epub digital book format is ideal for reading ebooks on phones, tablets, and e-readers.
Download EPUB
Want to read the full book?
Follow
گوش دادن
Now playing
سیستم‌های هایپرمدیا
0:00
-0:00
Now playing
سیستم‌های هایپرمدیا
0:00
-0:00
1x
Queue
Home
Swipe
Library
Get App
Try Full Access for 3 Days
Listen, bookmark, and more
Compare Features Free Pro
📖 Read Summaries
Read unlimited summaries. Free users get 3 per month
🎧 Listen to Summaries
Listen to unlimited summaries in 40 languages
❤️ Unlimited Bookmarks
Free users are limited to 4
📜 Unlimited History
Free users are limited to 4
📥 Unlimited Downloads
Free users are limited to 1
Risk-Free Timeline
امروز: دسترسی فوری
گوش دادن به خلاصه کامل بیش از ۲۶,۰۰۰ کتاب. بیش از ۱۲,۰۰۰ ساعت محتوای صوتی!
روز دوم: یادآوری دوره آزمایشی
به شما اطلاع می‌دهیم که دوره آزمایشی‌تان به‌زودی پایان می‌یابد.
روز سوم: شروع اشتراک شما
مبلغ اشتراک در تاریخ Jul 5,
کسر می‌شود. هر زمان قبل از آن می‌توانید لغو کنید.
Consume 2.8× More Books
2.8× more books Listening Reading
Our users love us
600,000+ readers
Trustpilot Rating
TrustPilot
4.6 Excellent
This site is a total game-changer. I've been flying through book summaries like never before. Highly, highly recommend.
— Dave G
Worth my money and time, and really well made. I've never seen this quality of summaries on other websites. Very helpful!
— Em
Highly recommended!! Fantastic service. Perfect for those that want a little more than a teaser but not all the intricate details of a full audio book.
— Greg M
Save 62%
Yearly
$119.88 $44.99/year/yr
$3.75/mo
Monthly
$9.99/mo
Start a 3-Day Free Trial
3 days free, then $44.99/year. Cancel anytime.
Unlock a world of fiction & nonfiction books
26,000+ books for the price of 2 books
Read any book in 10 minutes
Discover new books like Tinder
Request any book if it's not summarized
Read more books than anyone you know
#1 app for book lovers
Lifelike & immersive summaries
30-day money-back guarantee
Download summaries in EPUBs or PDFs
Cancel anytime in a few clicks
Scanner
Find a barcode to scan

We have a special gift for you
Open
38% OFF
DISCOUNT FOR YOU
$79.99
$49.99/year
only $4.16 per month
Continue
2 taps to start, super easy to cancel
Settings
General
Widget
Loading...
We have a special gift for you
Open
38% OFF
DISCOUNT FOR YOU
$79.99
$49.99/year
only $4.16 per month
Continue
2 taps to start, super easy to cancel