يحدِّد Storage Standard واجهة برمجة تطبيقات للتخزين الدائم واقتِراحات مساحة التخزين المتوفّرة، وبنية تخزين المنصة. نحن بصدد إطلاق واجهة برمجة تطبيقات لجعل عملية تفريغ مساحة التخزين باستمرار تحت ضغط شديد للذاكرة أكثر قابلية للتنبؤ. وهي متاحة اعتبارًا من الإصدار 122 من Chromium.
ما المشكلة التي يحلها معيار التخزين؟
عادةً، عندما تنفد مساحة التخزين على جهاز المستخدم، يتم فقدان البيانات المُخزَّنة من خلال واجهات برمجة التطبيقات، مثل IndexedDB أو localStorage
، بدون أن يتمكّن المستخدم من التدخل في الأمر. يمكن جعل ملف التخزين دائمًا من خلال استدعاء أسلوب
persist()
لواجهة
StorageManager
. ويطلب التطبيق من المستخدم النهائي في الوقت نفسه الحصول على الإذن ويغيّر ملف التخزين ليصبح دائمًا بعد منحه:
const persisted = await navigator.storage.persist();
if (persisted) {
/* Storage will not be cleared except by explicit user action. */
}
هذه الطريقة لطلب الاحتفاظ ببيانات التخزين هي إما كلّيّة أو لا شيء. لا تتوفّر طريقة للتعبير عن احتياجات ثبات أكثر تحديدًا. وتكون هذه المساحة كلها ضمن دلو تخزين واحد.
واجهة برمجة التطبيقات Storage Buckets API
تتمثل الفكرة الأساسية لواجهة برمجة التطبيقات Storage Buckets API في منح المواقع الإلكترونية إمكانية إنشاء مجموعات تخزين متعددة، حيث يمكن للمتصفّح اختيار حذف كل مجموعة بشكل مستقل عن المجموعات الأخرى. يتيح ذلك للمطوّرين تحديد أولوية إزالة التخزين للحرص على عدم حذف البيانات الأكثر أهمية.
مثال على حالة استخدام
لتوضيح الحالات التي تكون فيها حِزم التخزين مفيدة، تخيل تطبيق بريد إلكتروني. سيكون من غير المقبول أن يفقد التطبيق مسودات المستخدم غير المُرسَلة التي لا تتوفّر إلا على جهاز العميل. في المقابل، إذا كانت الرسائل محفوظة على خادم، قد لا يهتم المستخدم بإزالة بعض الرسائل الإلكترونية القديمة من البريد الوارد من العميل إذا كان المتصفّح يواجه ضغطًا كبيرًا على م��احة التخزين.
استخدام واجهة برمجة التطبيقات Storage Buckets API
إنشاء حزمة تخزين جديدة
يمكن إنشاء حزمة تخزين جديدة باستخدام طريقة open()
في واجهة StorageBucketManager
.
// Create a storage bucket for emails that are synchronized with the
// server.
const inboxBucket = await navigator.storageBuckets.open('inbox');
إنشاء حزمة تخزين جديدة دائمة
لضمان الاحتفاظ بحزمة التخزين، يمكنك تمرير وسيطات الخيارَين durability
وpersisted
إلى الطريقة open()
:
persisted
يحدِّد ما إذا كان يجب الاحتفاظ بمجموعة التخزين أم لا. القيم المسموح بها هيfalse
(الإعداد التلقائي) أوtrue
.durability
يقدّم تلميحًا للمتصفّح يساعده في موازنة أداء الكتابة مع انخفاض خطر فقدان البيانات في حال انقطاع التيار الكهربائي. القيم المسموح بها هي'relaxed'
(الإعداد التلقائي) أو'strict'
:- تحاول حِزم
'strict'
تقليل خطر فقدان البيانات في حال انقطاع التيار الكهربائي. وقد ينتج عن ذلك تدني تكلفة الأداء، ما يعني أنّ عمليات الكتابة قد تستغرق وقتًا أطول حتى تكتمل، وقد تؤثر في الأداء العام للنظام، وقد تستهلك المزيد من طاقة البطارية، وتؤدي إلى استنزاف جهاز التخزين بشكل أسرع. - قد "تفقد" حِزم
'relaxed'
عمليات الكتابة التي اكتملت في الثواني القليلة الماضية عند انقطاع التيار الكهربائي. في المقابل، قد تؤدي كتابة البيانات في هذه الحِزم إلى تحسين خصائص الأداء، وقد تسمح بزيادة مدة شحن البطارية، وقد تؤدي إلى إطالة عمر استخدام ملف التخزين. بالإضافة إلى ذلك، لن يؤدي انقطاع التيار الكهربائي إلى تلف البيانات بمعدّل أعلى من مثيله في'strict'
الحِزم.
- تحاول حِزم
// Create a storage bucket for email drafts that only exist on the client.
const draftsBucket = await navigator.storageBuckets.open('drafts', {
durability: 'strict', // Or `'relaxed'`.
persisted: true, // Or `false`.
});
الوصول إلى واجهات برمجة تطبيقات مساحة التخزين من حزمة تخزين
يكون كل حزمة تخزين مرتبطة بواجهات برمجة تطبيقات التخزين، مثل
IndexedDB أو واجهة
Cache أو واجهة
File. تعمل واجهات برمجة تطبيقات التخزين هذه كالمعتاد، إلا أنّ نقطة الدخول هي من واجهة StorageBucket
، على سبيل المثال،
StorageBucket.indexedDB
.
const inboxDb = await new Promise(resolve => {
const request = inboxBucket.indexedDB.open('messages');
request.onupgradeneeded = () => { /* migration code */ };
request.onsuccess = () => resolve(request.result);
request.onerror = () => reject(request.error);
});
تصحيح أخطاء حِزم التخزين في "أدوات مطوري البرامج"
راجِع حِزم التخزين في شجرة مخصّصة في قسم التطبيق > التخزين.