بتذكر منيح هذاك اليوم، قبل كم سنة. كنت قاعد في مكتبي، مبسوط على حالي وفنجان القهوة بإيدي. كنا لسه مطلقين تطبيق جديد للمدينة، تطبيق فيه كل إشي: أخبار، فعاليات، خدمات… شغل متعوب عليه، وتصميمه “مودرن” وحركات. كنت بتابع ردود الفعل الأولية، وكلها مديح وإعجاب. “شغل مرتب يا أبو عمر”، “واجهة بتجنن”، “أخيرًا صرنا عالميين”.
لحد ما وصلتني رسالة على الإيميل من حدا مسمي حاله “أبو أحمد”. الرسالة كانت قصيرة، وبسيطة، بس وقعها علي كان زي الصاعقة. كتبلي: “يعطيك العافية يا ابني، الشغل حلو، بس أنا زلمة كبير بالعمر ونظري على قدي. الألوان فايعة ببعضها ومش شايف أقرأ إشي، والحكي صغير كثير. حاولت أكبره، خرب كل إشي. الله يرضى عليك، لو تشوفولنا حل”.
في هذيك اللحظة، حسيت كل الفخر اللي كنت حاسس فيه تبخر. واجهتنا اللي كنا بنعتبرها تحفة فنية، كانت بالنسبة لأبو أحمد ولكثيرين غيره مجرد جدار، حصن منيع بيمنعهم من الوصول للمعلومة. تطبيقنا اللي كان المفروض يخدم “كل” أهل المدينة، كان في الحقيقة بيخدم بس اللي نظرهم 6/6 واللي أصابعهم سريعة. يومها، أدركت إننا بنينا قصرًا جميلًا، لكن نسينا نبني له مدخلًا للجميع. من هنا بدأت رحلتي الحقيقية مع عالم “الوصول الرقمي” أو الـ Accessibility.
ما هي “معايير الوصول الرقمي” (WCAG)؟ وليش هي مهمة؟
ببساطة شديدة يا جماعة، الـ Web Content Accessibility Guidelines أو (WCAG) هي مش مجرد كتالوج تقني أو قوانين جامدة. هي فلسفة، هي بوصلة أخلاقية بتوجهنا عشان نبني منتجات رقمية (مواقع، تطبيقات، أنظمة) للجميع، بدون أي استثناء.
فكر فيها هيك: لما تبني عمارة، القانون بيلزمك تعمل رامبات ومصاعد لذوي الاحتياجات الحركية. ليش؟ عشان المبنى يكون للكل. نفس المبدأ تمامًا بينطبق على العالم الرقمي. الـ WCAG هي “كود البناء” الرقمي اللي بيضمن إنه منتجك ما يستبعد حدا، سواء كان شخص كفيف بيستخدم قارئ شاشة، أو شخص عنده ضعف في رؤية الألوان، أو شخص ما بيقدر يستخدم الماوس بسبب إعاقة حركية، أو حتى شخص كبير في السن زي أبو أحمد.
الأهمية مش بس أخلاقية وإنسانية، مع إنها أهم إشي. الأهمية كمان تجارية! لما تصمم للجميع، أنت بتوسع شريحة مستخدميك بشكل هائل. وبتكسب ولائهم، لأنه المستخدم اللي بتحترمه وبتسهل عليه حياته، عمره ما بينساك.
الأركان الأربعة للوصول الرقمي (POUR)
عشان تسهل علينا المهمة، جماعة الخير اللي وضعوا معايير WCAG لخصوا كل المبادئ في أربعة أركان أساسية، وسموها (POUR). خلينا نفصصهم وحدة وحدة:
1. قابلية الإدراك (Perceivable)
المبدأ: لازم المستخدمين يقدروا يدركوا ويفهموا المحتوى المعروض بكل حواسهم المتاحة. يعني مش كل إشي بالنظر يا حبايب، في ناس “بتسمع” المحتوى سمع، وفي ناس “بتقرأه” بطريقة برايل.
نصيحة أبو عمر: غمّض عيونك لمرة، وخلّي حدا يوصفلك موقعك. هل الوصف واضح؟ إذا لأ، عندك مشكلة.
أمثلة عملية:
- النص البديل للصور (Alt Text): هاي مش بس عشان الـ SEO! قارئات الشاشة بتستخدمها عشان توصف الصورة للمستخدم الكفيف. الصورة بدون نص بديل هي مجرد فراغ بالنسبة له.
<!-- خطأ -->
<img src="knafeh.jpg">
<!-- صح -->
<img src="knafeh.jpg" alt="صورة لطبق كنافة نابلسية ساخنة بالجبنة البيضاء والقطر الذهبي">
- التباين اللوني (Color Contrast): مشكلة أبو أحمد الأساسية. لازم يكون في تباين كافٍ بين لون النص ولون الخلفية عشان الناس اللي عندها ضعف نظر أو عمى ألوان تقدر تقرأ بسهولة. في أدوات مجانية كثير بتفحصلك هالشي (زي “Adobe Color” أو إضافات للمتصفح مثل “WAVE”).
- التعليقات النصية للفيديو (Captions): أي فيديو فيه حكي لازم يكون معه تعليقات نصية (Captions)، مش بس للناس اللي عندها ضعف سمع، بل كمان للي بيتصفح في مكان عام وما معه سماعات!
2. قابلية التشغيل (Operable)
المبدأ: لازم كل مكونات الواجهة، من أزرار وقوائم وروابط، تكون قابلة للاستخدام والتشغيل بطرق مختلفة، ومش بس بالماوس.
نصيحة أبو عمر: قبل ما تسلّم أي صفحة، اترك الماوس على جنب، وحاول تتصفح كل إشي باستخدام كيبوردك فقط (مفاتيح Tab, Shift+Tab, Enter, Space). إذا علّقت في مكان وما قدرت تطلع منه (ما يسمى بالـ Keyboard Trap)، أو ما قدرت توصل لزر معين، معناها عندك شغل لازم تعمله.
أمثلة عملية:
- التنقل بالكيبورد: لازم المستخدم يقدر ينتقل بين كل العناصر التفاعلية باستخدام زر Tab، ويشوف بوضوح هو وين واقف (Focus Indicator). هاي أهم نقطة!
- استخدم العناصر الصحيحة (Semantic HTML): البركة في البساطة. ليش تخترع العجل وتعمل زر من عنصر `
` وتبرمجه من الصفر، بينما HTML معطيك عنصر `
سجل دخولك لعمل نقاش تفاعلي
كافة المحادثات خاصة ولا يتم عرضها على الموقع نهائياًآراء من النقاشات
لا توجد آراء منشورة بعد. كن أول من يشارك رأيه!
آخر المدونات
خوارزمياتخوارزمية A*: كيف أنقذتني من جحيم البحث الأعمى في مسارات لا تنتهي؟
مساراتنا كانت متاهة لا نهاية لها، وشخصيات ألعابنا تتصرف بغباء مطلق. في هذه المقالة، أشارككم قصة كيف أنقذتنا خوارزمية A* بـ "تخمينها الذكي" من جحيم...
تسويق رقميمحتوانا كان شبحًا في جوجل: كيف أنقذتنا ‘البيانات المنظمة’ (Structured Data) من جحيم التجاهل؟
كنّا ننتج محتوى عالي الجودة، لكن جوجل كان يتجاهله تمامًا. في هذه المقالة، أشارككم قصة كيف حولت البيانات المنظمة (Structured Data) موقعنا من شبح إلى...
برمجة وقواعد بياناتكودنا كان غارقًا في استعلامات SQL النصية: كيف أنقذتنا ‘مخططات الكائنات العلائقية’ (ORM) من جحيم الصيانة؟
أشارككم قصة من قلب المعركة البرمجية، كيف انتقلنا من فوضى استعلامات SQL المكتوبة يدويًا إلى عالم منظم وآمن باستخدام تقنيات ORM. هذه ليست مجرد مقالة...
الشبكات والـ APIsخدماتنا كانت مكشوفة وفوضوية: كيف أنقذتنا ‘بوابة الواجهات البرمجية’ (API Gateway) من جحيم الإدارة اليدوية والأمان المهترئ؟
أشارككم قصة حقيقية من قلب المعركة البرمجية، كيف انتقلنا من فوضى الخدمات المصغرة والأمان المهترئ إلى نظام مركزي وآمن. اكتشفوا معنا كيف كانت بوابة الواجهات...
الحوسبة السحابيةبيئاتنا كانت نسخًا مشوهة من بعضها: كيف أنقذتنا ‘البنية التحتية ككود’ (IaC) من جحيم الانحراف؟
هل عانيت يومًا من أن تطبيقك يعمل بشكل مثالي في بيئة التطوير ويفشل فشلاً ذريعًا في الإنتاج؟ لست وحدك. في هذه المقالة، أشارككم قصة حقيقية...
التوظيف وبناء الهوية التقنيةمقابلات تصميم النظم كانت صندوقًا أسود: كيف أنقذني ‘إطار عمل منهجي’ من جحيم الإجابات العشوائية؟
أتذكر تلك المقابلة جيدًا، حين تجمدت أمام السبورة البيضاء وأنا أحاول تصميم نظام "تويتر". في هذه المقالة، أشارككم الإطار العملي المنهجي الذي أنقذني من فوضى...
التوسع والأداء العالي والأحمالطلباتنا كانت تضرب قاعدة البيانات بلا رحمة: كيف أنقذنا ‘التخزين المؤقت’ (Caching) من جحيم الاستجابة البطيئة؟
في هذه المقالة، أشارككم قصة حقيقية عن كيفية تحول تطبيقنا من بطيء ومكلف إلى صاروخي الأداء بفضل تقنية التخزين المؤقت (Caching). سنغوص في أعماق هذه...
التكنلوجيا المالية Fintechمعاملاتنا كانت تُسرق في وضح النهار: كيف أنقذنا ‘الكشف عن الاحتيال بالتعلم الآلي’ من جحيم الخسائر المالية؟
في هذه المقالة، أشارككم قصة حقيقية عن مواجهتنا لعمليات احتيال كادت أن تدمر شركتنا الناشئة في التكنولوجيا المالية. سأغوص معكم في تفاصيل كيف استخدمنا تعلم...
البنية التحتية وإدارة السيرفراتإعداداتنا كانت تتغير عشوائيًا: كيف أنقذنا Ansible من جحيم الانحراف في التكوين (Configuration Drift)؟
أشارككم قصة حقيقية من قلب المعركة مع الخوادم، حين كانت إعداداتنا تتغير بشكل غامض مسببةً أعطالاً متكررة. اكتشفوا معنا كيف كان Ansible هو طوق النجاة...