الانتقالات وحماية البيانات في CSS
تتيح لك الخصائص المخصّصة في CSS، والتي تُعرف أيضًا باسم متغيّرات CSS ، تحديد خصائصك الخاصة في CSS واستخدام قيمها في CSS. على الرغم من أنّها مفيدة للغاية في الوقت الحالي، إلا أنّها تتضمّن عيوبًا يمكن أن تصعِّب استخدامها: يمكن أن تتضمّن أي قيمة، لذا قد يتم عمدًا استبدالها بشيء غير متوقّع، وترث قيمها دائمًا من العنصر الرئيسي، ولا يمكنك نقلها. من خلال المستوى 1 من واجهة برمجة التطبيقات CSS Properties and Values API في Houdini، المتوفّرة الآن في الإصدار 78 من Chrome، تم تجاوز هذه العيوب، ما يجعل خصائص CSS المخصّصة فعّالة بشكلٍ لا يصدق.
ما هو Houdini؟
قبل الحديث عن واجهة برمجة التطبيقات الجديدة، لنتحدث عن Houdini بسرعة. تم إنشاء CSS-TAG Houdini Task Force، والمعروفة باسم CSS Houdini أو Houdini ببساطة، بهدف "تطوير ميزات توضّح "السحر" الخاص بتحديد الأنماط والتنسيق على الويب". تم تصميم مجموعة مواصفات Houdini للاستفادة من قدرات محرّك عرض المتصفّح، ما يتيح بدوره معرفة أكثر تفصيلاً عن أنماطنا والقدرة على توسيع نطاق محرّك العرض. وبفضل ذلك، أصبح من الممكن أخيرًا استخدام قيم CSS المكتوبة في JavaScript واستخدام polyfilling أو إنشاء CSS جديد بدون التأثير في الأداء. تتيح لك أداة Houdini تعزيز قدراتك الإبداعية على الويب.
المستوى 1 من واجهة برمجة التطبيقات لخصائص CSS وقيمها
يتيح لنا المستوى 1 من واجهة برمجة تطبيقات خصائص CSS وقيمها (Houdini Props and Vals) إنشاء بنية لخصائصنا المخصّصة. هذا هو الوضع الحالي عند استخدام الخصائص المخصصة:
.thing {
--my-color: green;
}
وبما أنّ السمات المخصّصة لا تحتوي على أنواع، يمكن إلغاء تطبيقها بطرق غير متوقّعة. على سبيل المثال، فكِّر في ما سيحدث إذا حدّدت --my-color
باستخدام عنوان URL.
.thing {
--my-color: url('not-a-color');
color: var(--my-color);
}
في هذه الحالة، لا يعلم البرنامج أنّ عنوان URL ليس قيمة ملفتة
للنظر. عند استخدامها، يتم الرجوع إلى القيم التلقائية (أسود لـ color
،
شفّاف لـ background
). باستخدام عناصر وقيم Houdini، يمكن
تسجيل السمات المخصّصة ليتمكّن المتصفّح من معرفة القيمة التي يجب أن تظهر.
والآن، تمّ تسجيل الخاصية المخصّصة --my-color
كلون. يُعلم ذلك المتصفّح بأنواع القيم المسموح بها وكيفية كتابتها ومعالجتها.
بنية موقع مسجَّل
يبدو عملية تسجيل الموقع كما يلي:
window.CSS.registerProperty({
name: '--my-color',
syntax: '<color>',
inherits: false,
initialValue: 'black',
});
ويتوافق مع الخيارات التالية:
name: string
اسم السمة المخصّصة.
syntax: string
كيفية تحليل السمة المخصّصة يمكنك العثور على قائمة كاملة بالقيم المحتملة في مواصفات قيم CSS ووحداتها. الإعداد التلقائي هو *
.
inherits: boolean
ما إذا كان يرث قيمة العنصر الرئيسي وتكون القيمة التلقائية هي true
.
initialValue: string
القيمة الأولية للسمة المخصّصة.
نلقي نظرة عن كثب على syntax
. هناك عدد من ال options
الصالحة
التي تتراوح بين الأرقام والألوان وأنواع
<custom-ident>
. يمكن أيضًا تعديل بناء الجملة هذه باستخدام القيم التالية
- يشير إلحاق
+
إلى أنّه يقبل قائمة مفصولة بمسافات لقيم هذه البنية. على سبيل المثال،<length>+
ستكون قائمة مفصولة بمسافات لقياس الطول - يشير إلحاق
#
إلى أنّه يقبل قائمة مفصولة بفواصل لقيم هذه البنية. على سبيل المثال،<color>#
هي قائمة مفصولة بفواصل ل الألوان. - تشير إضافة
|
بين بناء الجملة أو المعرّفات إلى أنّ أيًا من الخيارات المتوفّرة صالح. على سبيل المثال، يسمح<color># | <url> | magic
باستخدام قائمة بألوان مفصولة بفواصل أو عنوان URL أو الكلمةmagic
.
ألعاب حظ
هناك خطأان في عناصر Houdini وVals. الأولى هي أنّه بعد تحديد الموقع الإلكتروني، ما مِن طريقة لتعديله، وستؤدي محاولة إعادة تسجيل أحد المواقع إلى ظهور رسالة خطأ تشير إلى أنّه سبق أن تم تحديده.
ثانيًا، على عكس المواقع العادية، لا يتم التحقّق من صحة المواقع المسجّلة عند تحليلها. بل يتم التحقق من صحتها عند حسابها. وهذا يعني أنّه لن تظهر القيم غير الصالحة على أنّها غير صالحة عند فحص خصائص العنصر، ولن يؤدي تضمين خاصية غير صالحة بعد خاصية صالحة إلى الرجوع إلى القيمة الصالحة. ومع ذلك، ستتم إعادة استخدام القيمة التلقائية للخاصية المسجّلة إذا كانت الخاصية غير صالحة.
إضافة مؤثرات متحركة إلى الخصائص المخصّصة
يوفّر السمة المخصّصة المسجّلة مكافأة ممتعة بالإضافة إلى التحقّق من النوع: إمكانية إضافة مؤثرات متحركة إليها. يظهر مثال على صورة متحركة أساسية على النحو التالي:
<script>
CSS.registerProperty({
name: '--stop-color',
syntax: '<color>',
inherits: false,
initialValue: 'blue',
});
</script>
<style>
button {
--stop-color: red;
transition: --stop-color 1s;
}
button:hover {
--stop-color: green;
}
</style>
عند تمرير مؤشر الماوس فوق الزر، سيتغيّر لونه من الأحمر إلى الأخضر. بدون تسجيل الخاصية، سيتم الانتقال من لون إلى آخر. وبدون التسجيل، لا يعرف المتصفّح ما يمكن توقّعه بين القيمة والقيمة التالية، وبالتالي لا يمكن ضمان القدرة على الانتقال بين القيمتَين. يمكن الانتقال إلى جزء آخر في هذا المثال، مع ذلك، لتحريك تدرجات CSS! يمكن كتابة ملف CSS التالي باستخدام الموقع المسجَّل نفسه:
button {
--stop-color: red;
background: linear-gradient(var(--stop-color), black);
transition: --stop-color 1s;
}
button:hover {
--stop-color: green;
}
سيؤدي ذلك إلى إضافة تأثير متحركة إلى السمة المخصّصة التي تشكّل جزءًا من linear-gradient
، وبالتالي
إضافة تأثير متحركة إلى التدرّج اللوني الخطي. يمكنك الاطّلاع على Glitch أدناه للاطّلاع على التعليمات البرمجية الكاملة
في العمل والتجربة بنفسك.
الخاتمة
هوديني في طريقه إلى استخدام المتصفحات، ومعه، أصبح هناك طرق جديدة تمامًا للعمل مع وتوسيع نطاق CSS. بعد طرح Paint API، أصبح لدينا الآن أدوات إبداعية إضافية، مثل "العناصر المخصّصة" و"القيم المخصّصة"، ما يتيح لنا تحديد خصائص CSS المكتوبة واستخدامها لإنشاء تصاميم جديدة ومثيرة وإضافة مؤثرات إليها. لا يزال هناك المزيد قريبًا في قائمة انتظار مشاكل هوديني التي يمكنك من خلالها تقديم ملاحظات ومعرفة الخطوات التالية التي سيتّخذها "هوديني". تم إنشاء Houdini لتطوير ميزات توضّح "السحر" في التصميم والتنسيق على الويب، لذا ننصحك بالاستفادة من هذه الميزات السحرية.
الصورة مقدمة من Maik Jonietz على Unsplash