همانطور که میدانیم هر نعمت و هر امکانی که در دنیا وجود دارد برای همه انسانها خلق شده است و ما انسانها هستیم که شرایط را طوری ایجاد میکنیم که امکانات فقط برای یک قشر خاص در دسترس قرار بگیرد! میتوانید به وضعیت کلی مکانهای عمومی و هزارن مثالی که وجود دارد اشاره کرد که این موارد برای همگی در دسترس نیست و متاسفانه افراد کمتوان یا دارای معلولیت نمیتوانند به دلیل کوتاهی سایر افراد و نبود نظارت و آگاهی کافی از آنها استفاده کنند.
در این مقاله میخواهم به این مورد در حوزه وب اشاره کنم که چطور وب یا برنامه ای که طراحی میکنیم در دسترس همه قرار بگیرد، و جدا از مسایل اخلاقی، چرا باید آنها را رعایت کنیم.
web accessibility means that EVERYONE can use the Web.Accessibility is about EVERYONE.
کنسرسیوم وب (World Wide Web Consortium یا W3C) کنسرسیومی (ائتلاف چندین شرکت به صورت هماهنگ و دارای هدف یکسان) است که استانداردهای نرمافزاری لازم را برای وب تولید میکند. دلیل وجودی این کنسرسیوم کسب اطمینان در مورد سازگاری و توافق میان اعضای شرکتهای مختلف در زمینهٔ استفاده از استانداردهای نو است.
هدف از معرفی W3C این بود که به اصلهایی که برای وب مشخص کرده اند اشاره کنم، برای مطالعه بیشتر میتوانید World Wide Web Consortium و یا ABOUT W3C را مطالعه کنید. در اهدافی که این کنسرسیوم دنبال میکند یکسری اصل برای دیزاینهای وب مشخص کرده است که میتوانید لیست آنها را در W3C MISSION مطالعه کنید ولی من به دو اصلی که مربوط به موضع این مقاله است اشاره میکنم.
ارزش اجتماعی وب این است که ارتباطات انسانی، تجارت و فرصت هایی را برای اشتراک دانش میسر می سازد. یکی از اهداف اصلی W3C این است که این مزایا در دسترس همه افراد فارغ از نوع سخت افزار، نرم افزار، زیرساخت شبکه، زبان مادری، فرهنگ، موقعیت جغرافیایی یا توانایی جسمی یا روانی که دارند قرار بگیرد.
تعداد دستگاه های مختلفی که می توانند به وب دسترسی پیدا کنند، بسیار زیاد شده است. تلفن های همراه، تلفنهای هوشمند، دستیاران دیجیتال شخصی ، سیستم های پاسخ صوتی، کیوسک ها و حتی برخی از لوازم خانگی همگی میتوانند به وب دسترسی پیدا کنند.
نکته: W3C به این صورت کار میکند که ابتدا موضوعات مهمی که نیاز است برای آنها استانداردی مشخص شود مطرح میشوند و پروپوزال آنها ایجاد و به گروهی assign میشود، سپس یک راهنما برای آن ایجاد و بازبینی میشود و در نهایت توصیهها و پیشنهادات آنها طی یک راهنما منتشر میشود.
WCAG) 2.1 طیف گسترده ای از توصیه ها برای دسترسی بیشتر به محتوای وب را در بر می گیرد. پیروی از این دستورالعمل ها باعث می شود محتوا برای طیف گسترده تری از افراد دارای معلولیت از جمله برای نابینایی و کم بینایی، ناشنوایی و کم شنوایی، حرکات محدود، ناتوانی در گفتار، حساسیت به نور و ترکیب این موارد و برخی از امکانات برای ناتوانی در یادگیری و محدودیت های شناختی را تا حدود بسیار زیادی در دسترس قرار بگیرد.
این دستورالعمل ها به دسترسی به محتوای وب در دسکتاپ، لپ تاپ، تبلت و دستگاه های تلفن همراه می پردازد. پیروی از این دستورالعمل ها باعث می شود محتوای وب بیشتر به طور کلی برای کاربران قابل استفاده باشد. سرفصلها به صورت زیر هستند:
مطالعه بیشتر در رابطه با این موارد
۱. افزایش مارکت و تعداد مخاطبان وب (نفوذ در بازار)
۲. رشد SEO وبسایت
۳. ایجاد وجه و روابط عمومی مثبت
۴. از تبعیض و عوارضی که قانون برای برنامههایی که این ویژگیها را ندارند در امان خواهید بود. (این مورد در ایران بیمعنی است!)
۵. بهبود کارایی و کدهای تمیزتر
۱. Responsive Web Design
۲. Good Color Choices
۳. Good Typography
۴. Simple, Understandable Forms
۵. Easy To Touch
۶. Subtle Motion
این موضوع بسیار گسترده است و در این مقاله نمیتوان به تمام جزئیات و بخشهای آن اشاره کرد، اگر بخواهیم به صورت کلی این موضوع را توضیح دهیم باید وبسایتی که طراحی میکنیم در تمام دستگاهها قابل استفاده و نمایش باشد، از لحاظ navigation و typography و ... به صورتی واضح در دسترس باشد.
طبق آمار از هر ۱۲ مرد یک نفر و از هر ۲۰۰ زن یک نفر کوررنگی دارد و یا به عبارتی ۵ درصد از جمعیت کوررنگی دارند. رایج ترین نوع کوررنگی Red Deficiencies یا کوری رنگ ناشی از عدم حساسیت به نور قرمز است که باعث سردرگمی سبزی ها ، قرمزها و زردی ها می شود. علاوه بر این مورد میتوان به Green Deficiencies و Blue Deficiencies نیز اشاره کرد که در تصویر زیر تفاوت تشخیص رنگها را میتوانید مشاهده کنید.
برای مطالعه بیشتر مقاله Accessibility for Visual Design را مطالعه نمائید.
علاوه به موارد ذکر شده دستهای از افراد هستند که کوررنگی کامل دارند و همه رنگها را طیفهای از سیاه و سفید میبینند.
نکته ای که لازم است در نظر بگیریم این است که دیوایسها و ابزارهای مختلف نیز نمایش رنگها را تغییر میدهند علاوه بر این در محیطی که هستیم و تاریکی و روشنی محیط نیز در نمایش و دیدن کامل رنگها تاثیر میگذارد که در این حالت Contrast رنگها میتواند کمک کننده خوبی باشد.
یکی از مهمترین نکات یک وبسایت تایپوگرافی و نمایش درست متنهایی است که در وبسایت وجود دارد. برای تایپوگرافی سبک حروف و نوع فونت، خوانایی و نمایش درست سلسله مراتب مطالب از اهمیت زیادی برخوردار است.
برای اینکه تایپوگرافی مناسبی داشته باشیم باید موارد زیر را در نظر بگیریم:
۱. Font Size : معمولا سایز فونتها بین ۱۶ تا ۲۰ پیکسل در نظر گرفته میشود ولی نکته ای وجود دارد این است که ما نباید از واحد px یا پیکسل استفاده کنیم و به جای آن از em , rem استفاده میکنیم تا بر اساس نوع مرورگر و دیوایسی که داریم سایز آن برای کاربر به سبک درست نمایش داده شود. وقتی ما از پیکسل استفاده کنیم این اختیار را از کاربر سلب میکنیم که بر اساس تنظیمات مرورگرش وبسایت ما را مشاهده کند.
۲. Contrast : رنگ فونت در بخشهای مختلف سایت از اهمیت ویژه ای برخوردار است که قابلیت خوانایی را کاهش ندهد.
۳. line-height : ارتفاع خطها و فاصله آنها از هم، تعداد کاراکترهای هر پاراگراف هم نکته مهمی است که رعایت آن به خوانایی مطالب کمک میکند. به تصویر زیر دقت کنید:
۴. Text Justification : یکی از نکات مهم که معمولا به آن توجه نمیشود justify متنهاست که عدم رعایت آن باعث پایین آمدن خوانایی متن میشود. پیشنهاد میکنم که متن را justify نکنید. به تصویر زیر دقت کنید.
نکته: برای رعایت تایپوگرافی معمولا برای line-height واحد در نظر نمیگیریم مثلا نمینویسیم : line-height: 1.7em فقط مقدار عددی آن را مینویسیم همچنین font-size را داخل تگهای html, body مقدار 100% درنظر میگیریم که بر اساس تنظیمات browser و مقادیری که ما بر حسب em وارد کردیم تنظیم شود.
یکی از مهمترین بخشهایی که با کاربران تعامل دارد فرمهای وبسایت هستند که لازم است ساده، واضح و قابل درک باشند. هنگام پیاده سازی یک فرم نکات زیر بسیار مهم هستند. به تصویر زیر دقت کنید، یک فرم که مشکلات Accessibility را دارد.
۱. label هایی که برای هر فیلد قرار میدهیم باید واضح باشند.
۲. مقدار placeholder هیچ وقت نمیتواند جایگزین مقدار label باشد.
۳. وقتی میخواهیم کاربر مقدار فیلدی را با شرایطی وارد کنید باید توضیحاتی برای آن بنویسیم (مثلا برای رمز عبور حداقل ۸ کاراکتر باشد.)
۴. هنگامی که کاربر مقادیر را وارد کرد و با خطایی مواجه شد تنها به تغییر رنگ بوردر فیلد اکتفا نکنیم و عبارتی را کنار آن بنویسیم چونکه همانطور که در موارد بالا به افرادی که کوررنگی دارند اشاره کردیم قادر به تشخیص خطا نیستند.
۵. مقادیری که الزامی هستند را با عبارت الزامی یا required مشخص کنیم.
به تصویر فرم زیر دقت کنید، بعد از اصلاح موارد فوق به صورت زیر خواهد بود.
حداقل سایزی که بدون مشکل در صفحات دستگاههای لمسی بدون مشکل و خطا قابل استفاده است ۴۴ تا ۴۸ پیکسل است. یعنی فرض کنید که کاربر میخواهد یک دکمه را با انگشت اشاره انتخاب کند سایز این دکمه باید به نوعی باشد که بدون مشکل و خطا انتخاب شود باید حداقل سایز آن ۴۴ تا ۴۸ پیکسل باشد. به تصویر زیر دقت کنید.
وبسایت ما باید قابلیت این را داشته باشد که کاربر بتواند با کیبورد از آن استفاده کند، یعنی با استفاده از کلیدهای Tab بتوانیم بین منوها و بخشهای سایت حرکت کنیم و صفحات مختلف را تغییر دهیم. در تصویر زیر که از مقاله Accessibility Help گرفته شده است نحوه حرکت بین بخشهای مختلف صفحه با کلیدهای کیبورد را مشخص کرده است. برای مثال توی همین وبلاگ من اگر الان کلید Tab را فشار دهید منوهای بالای صفحه انتخاب میشوند و میتوانید با حرکت بین آنها و فشار دادن دکمه Enter وارد بخش موردنظر شوید.
نباید با استفاده از css و javascript این قابلیت را غیرفعال کنیم.
مطالعه بیشتر: Keyboard-navigable JavaScript widgets
با رشد وب و به وجود امدن امکانات جدید و افزایش تعامل کاربر با صفحات وب، ایجاد انیمیشنها و حرکتها با استفاده از css و جاوااسکریپت ساده تر و پراستفاده تر شده است اما نکته ای که حائز اهمیت است این است که هر حرکت و انیمیشنی باید یک هدفی را دنبال کند. به خاطر افراط در استفاده از انیمیشنها و حرکتهایی که بعد از کلیک ماوس اتفاق میافتد کاربر سرگیجه میگیرید و حس خوبی از آن دریافت نمیکند، این موضوع شاید در ابتدا عجیب به نظر برسد ولی هرچقدر وبسایت را سادهتر و نرمتر در نظر بگیرید امکان استفاده راحتتر از آن بیشتر است.
یک ایده جذاب میتواند این باشد که امکانی را فرآهم نمایید که کاربر انیمیشنهای وبسایت را غیرفعال نماید یا این کار تجربه کاربر از کار با وبسایت لذت بخشتر خواهد بود.
در این مقاله به کلیت این موضوع پرداختم که Web Accessibility به چه موضوعی اشاره میکند و چرا باید برای ما اهمیت داشته باشد. برای اینکه این موضوع یه یک فرهنگ درست کاری تبدیل شود بهترین کار این است که از خودمون و پروژه های خودمون شروع کنیم وقتی پروژه ای انجام میدهیم همانطور که زمان و هزینه ای برای واکنشگرا بودن پروژه در نظر میگیریم لازم است بخش Web Accessibility را نیز لحاظ کنیم و مطمئنا با اینکار به خودمون کمک کردیم.
بخش دوم مقاله: وب در دسترس برای همه! بخش دوم