عندما سمعت لأول مرة عن هذه المصطلحات اعتقدت، حسنًا، إنهم يفعلون نفس الأشياء تقريبًا مع موضوعهم المنفصل. إذن لماذا نحتاج إلى هذين المصطلحين؟
ولكن لأقول لك الحقيقة، هناك اختلافات كبيرة بين هذين المصطلحين وكيفية تصرفهما.
سنحاول الشرح بالتفصيل.
الأرضية المشتركة بين هذين الاثنين هي
عامل الويب
عامل الخدمة
دورة حياة عامل الخدمة
1. تسجيل
if ('serviceWorker' in navigator) { // wrap it in try/catch / promisses await navigator.serviceWorker.register('/service-worker.js') }
2. تثبيت
الكود أدناه الذي نحتاج إلى كتابته في service-worker.js
self.addEventListener('install', (event) => { // do your operations })
3. التنشيط
self.addEventListener('activate', (event) => { // Do your Operation })
4. عاطل
5. جلب/رسالة
self.addEventListener('fetch', (event) => { // Do your Opeation })
6. الإنهاء
سوف يحافظ على العاملين في الخدمة لفترة طويلة جدًا.
مثال:-
في chrome افتح هذا الرابط هناك وسترى الكثير من عمال الخدمة معلقين، ويمكنك القيام بالكثير من الأشياء مثل فحص/بدء وإرسال رسالة.
chrome://serviceworker-internals/
كيف يمكننا إيقاظ العاملين في الخدمة حتى لو كان المتصفح مغلقًا.
ملحوظة:-
لهذا الغرض تحديدًا، يمكننا استخدام الدفع للاستيقاظ، ولكن لهذا الاستخدام يجب منح إذن الإعلام للمتصفح، وإلا فلا توجد طريقة.
هناك طرق أخرى ذات صلة عندما يكون المتصفح مفتوحًا
1. جلب الحدث
self.addEventListener('fetch', event => { // Handle fetch event });
2. رسالة
self.addEventListener('message', (event) => { // Handle message Event })
3. يدفع
self.addEventListener('push', (event) => { // Handle Push Event })
4. حدث المزامنة
self.addEventListener('sync', (event) => { // handle background Sync Event })
مرجع
تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3