پیش کش با Workbox

یکی از ویژگی‌های سرویس‌کار این است که می‌توانند فایل‌ها را در حافظه پنهان هنگام نصب سرویس‌کار ذخیره کنند. این به عنوان "precaching" شناخته می شود. پیش کش این امکان را فراهم می کند تا فایل های کش شده را بدون رفتن به شبکه به مرورگر ارائه دهید. از پیش کش برای دارایی های حیاتی که سایت شما به آنها نیاز دارد حتی در حالت آفلاین استفاده کنید: صفحه اصلی، سبک ها، تصویر بازگشتی و اسکریپت های ضروری.

استفاده از Workbox برای پیش کش اختیاری است. شما می توانید کد خود را برای پیش کش کردن دارایی های حیاتی هنگام نصب سرویس دهنده بنویسید. مزیت اصلی استفاده از Workbox کنترل نسخه خارج از جعبه آن است. برای به‌روزرسانی دارایی‌های از پیش کش شده با استفاده از Workbox با مشکل کمتری مواجه خواهید شد تا اینکه مجبور باشید نسخه‌سازی و به‌روزرسانی این فایل‌ها را خودتان مدیریت کنید.

پیش کش آشکار می شود

پیش کش توسط لیستی از URL ها و اطلاعات مربوط به نسخه سازی برای هر URL هدایت می شود. روی هم، این اطلاعات به عنوان مانیفست پیش کش شناخته می شود. مانیفست «منبع حقیقت» برای وضعیت همه چیزهایی است که در پیش کش برای یک نسخه معین از یک برنامه وب قرار دارند. یک مانیفست پیش کش، در قالب استفاده شده توسط Workbox ، چیزی شبیه به:

[{
  url: 'app.abcd1234.js'
}, {
  url: 'offline.svg',
  revision: '7836745f'
}, {
  url: 'index.html',
  revision: '518747aa'
}]

هنگامی که سرویس‌کار نصب می‌شود، سه ورودی حافظه پنهان برای هر یک از سه URL فهرست شده در حافظه پنهان ایجاد می‌شود. اولین دارایی دارای اطلاعات نسخه‌سازی است که قبلاً در URL آن گنجانده شده است ( app نام فایل واقعی است و .abcd1234 حاوی اطلاعات نسخه‌سازی است، درست قبل از پسوند فایل .js ). ابزارهای ساخت Workbox می‌توانند این را تشخیص دهند و یک فیلد تجدیدنظر را حذف کنند. دو دارایی دیگر هیچ اطلاعات نسخه‌سازی را در URL‌های خود ندارند، بنابراین ابزارهای ساخت Workbox یک فیلد revision جداگانه ایجاد می‌کنند که حاوی هش از محتوای فایل محلی است.

ارائه منابع از پیش ذخیره شده

افزودن دارایی ها به حافظه نهان تنها بخشی از داستان پیش کش است – هنگامی که دارایی ها در حافظه پنهان ذخیره شدند، باید به درخواست های خروجی پاسخ دهند. این به یک شنونده رویداد fetch در سرویس‌کار شما نیاز دارد که بتواند بررسی کند کدام URL‌ها از پیش ذخیره شده‌اند، و پاسخ‌های ذخیره‌شده را به‌طور قابل‌اعتماد بازگرداند و شبکه را در این فرآیند دور بزند. از آنجایی که کارمند سرویس کش را برای پاسخ‌ها بررسی می‌کند (و از آن‌هایی که قبل از شبکه استفاده می‌شود)، به این استراتژی cache-first گفته می‌شود.

به روز رسانی های کارآمد

مانیفست پیش کش نمایش دقیقی از حالت کش مورد انتظار را ارائه می دهد. اگر ترکیب URL/بازبینی در مانیفست تغییر کند، یک سرویس‌کار می‌داند که ورودی حافظه پنهان قبلی دیگر معتبر نیست و باید به‌روزرسانی شود. تنها به یک درخواست شبکه نیاز دارد که به‌طور خودکار توسط مرورگر به‌عنوان بخشی از بررسی به‌روزرسانی کارگر سرویس انجام می‌شود تا مشخص شود کدام URLهای پیش‌کش شده باید به‌روزرسانی شوند.

به روز رسانی منابع از پیش ذخیره شده

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

اگر یک URL موجود با یک فیلد ویرایش جدید وجود داشته باشد، یا هر نشانی اینترنتی اضافه شده یا از مانیفست حذف شده باشد، این نشانه ای برای سرویس دهنده شما است که به عنوان بخشی از install و activate کنترل کننده رویداد، باید به روز رسانی انجام شود. به عنوان مثال، اگر تغییراتی در سایت خود ایجاد کرده اید و آن را بازسازی کرده اید، ممکن است آخرین مانیفست پیش کش شما دچار تغییرات زیر شده باشد:

[{
  url: 'app.ffaa4455.js'
}, {
  url: 'offline.svg',
  revision: '7836745f'
}, {
  url: 'index.html',
  revision: '518747aa'
}]

هر یک از این تغییرات به کارمند خدمات شما می‌گوید که باید درخواست‌های جدیدی برای به‌روزرسانی ورودی‌های ذخیره‌شده قبلی ( 'offline.svg' و 'index.html' ) و ذخیره کردن URLهای جدید ( 'app.ffaa4455.js' ) و همچنین حذف برای پاک کردن URL هایی که دیگر استفاده نمی شوند ( 'app.abcd1234.js' ).

تجربه نصب واقعی "فروشگاه برنامه".

یکی دیگر از مزایای پیش کش این است که می توانید تجربه ای را به کاربران خود ارائه دهید که در غیر این صورت دستیابی به آن در خارج از نصب «اپ استور» دشوار خواهد بود. هنگامی که کاربر برای اولین بار از هر صفحه ای در برنامه وب شما بازدید می کند، می توانید به طور بالقوه تمام URL های مورد نیاز برای نمایش هر یک از نماهای برنامه وب خود را قبل از موعد، بدون نیاز به منتظر ماندن تا بازدید از هر نما، از قبل ذخیره کنید.

هنگامی که کاربر یک برنامه را نصب می کند، انتظار دارد همه قسمت ها به سرعت نمایش داده شوند، نه فقط نماهایی که در گذشته به آن ها رفته اند. پیش کش همان تجربه را برای برنامه های وب به ارمغان می آورد.

کدام یک از دارایی های شما باید precach شوند؟

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

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

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

ابزارهای ساخت Workbox با گفتن تعداد موارد موجود در مانیفست پیش کش و همچنین اندازه کل محموله پیش کش به شما کمک می کند.

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