پر کردن شکاف

ساختن برای وب را آسان تر می کند.

وقتی با توسعه‌دهندگان صحبت می‌کنیم، چه به صورت جداگانه یا از طریق نظرسنجی‌هایی مانند وضعیت CSS ، مکرراً همان چیزها را می‌شنویم. برای توسعه‌دهندگان، ساختن وب‌سایت‌ها و برنامه‌هایی که در مرورگرها به خوبی کار می‌کنند، دشوار است، و برایشان سخت است که بدانند ویژگی‌های جدید هیجان‌انگیز چه موقع ایمن هستند.

شکاف فلکس باکس

به عنوان مثالی از یک ویژگی مشکل ساز، ویژگی gap به شما امکان می دهد بین موارد grid یا flex یا ستون ها در یک ظرف چند رنگ فاصله ایجاد کنید. در حالی که ما برای مدت طولانی column-gap در چند وجهی داشته ایم، ویژگی برای اولین بار در طرح بندی شبکه ای به عنوان grid-gap ، همراه با grid-column-gap و grid-row-gap ظاهر شد.

درست پس از اینکه چیدمان شبکه در مرورگرها قرار گرفت، ویژگی به همراه row-gap و column-gap به عنوان gap تغییر نام داد. سپس مشخص شد که در طرح بندی انعطاف پذیر نیز کار کند. تغییر نام به این معنی است که ما چندین ویژگی نداریم که یک کار را انجام دهند.

.box {
 
display: flex;
 
gap: 1em;
}

فایرفاکس این ویژگی را برای طرح‌بندی‌های انعطاف‌پذیر در اکتبر ۲۰۱۸ ارسال کرد. این ویژگی تا ژوئیه ۲۰۲۰ در Chrome نشان داده نشد و به دنبال آن Safari در آوریل ۲۰۲۱ عرضه شد. این بدان معناست که دو سال و شش ماه فاصله وجود داشت تا بتوانیم با خیال راحت از gap استفاده کنیم. در واقع، برای اکثر توسعه دهندگان، به دلیل نیاز به پشتیبانی از نسخه های مرورگر قدیمی تر از آخرین، انتظار بسیار طولانی تر بود. پشتیبانی از gap در طرح‌بندی انعطاف‌پذیر با این واقعیت که ما نمی‌توانیم از پرس‌وجوهای ویژگی برای شناسایی پشتیبانی شکاف در طرح‌بندی انعطاف‌پذیر استفاده کنیم، مشکل‌سازتر شد. از آنجایی که ویژگی gap در grid پشتیبانی می‌شود، @supports (gap:1em) true خواهد شد.

یک مشکل دیگر این است که وقتی یک ویژگی جدید در یک مرورگر قرار می‌گیرد، مردم شروع به صحبت در مورد آن و اشتراک‌گذاری نسخه‌های نمایشی می‌کنند. این اغلب خیلی قبل از اینکه این ویژگی در هر مرورگر پایداری باشد شروع می شود. این می تواند برای توسعه دهندگان گیج کننده یا حداقل ناامید کننده باشد. به طور مکرر، همه جا درباره ویژگی های جدید براق صحبت می شود، و سپس متوجه می شوید که به دلیل عدم پشتیبانی نمی توانید از آنها استفاده کنید.

چرا شکاف هایی در حمایت وجود دارد؟

این پستی نیست که انگشت یک مرورگر را به دلیل کند بودن آن نشانه می رود. اگر به ویژگی‌های پلتفرم مختلف نگاه کنید، متوجه خواهید شد که مرورگرهای مختلف در ویژگی‌های مختلف حرف اول را می‌زنند.

بیشتر ویژگی ها در یک مرورگر نمونه اولیه خواهند شد. برای مثال، مشخصات طرح‌بندی شبکه برای اولین بار توسط مایکروسافت ایجاد شد و به شکل اولیه در اینترنت اکسپلورر 10 پیاده‌سازی شد. یک مهندس در موزیلا کارهای زیادی را انجام داد تا بفهمد زیرشبکه چگونه باید رفتار کند، و بنابراین این ویژگی ابتدا در فایرفاکس قرار گرفت. ما شاهد این هستیم که Safari در برخی از عملکردهای رنگی جدید و هیجان انگیز پیشرو است.

در حالی که یک مرورگر ممکن است در نمونه سازی پیشرو باشد، نمایندگان همه مرورگرها (و سایر سازمان ها) در گروه کاری CSS درباره ویژگی های CSS بحث می کنند. بسیار مهم است که یک ویژگی در همه مرورگرها قابل پیاده سازی باشد و به گونه ای طراحی نشده باشد که اجرای آن در یک مرورگر غیرممکن باشد. این منجر به شکاف دائمی در پشتیبانی و عدم پذیرش این ویژگی می شود.

با این حال، وقتی نوبت به پیاده سازی یک ویژگی می رسد، باید در کنار سایر ویژگی های ممکن برای آن مرورگر اولویت بندی شود. و، گاهی اوقات چیزهایی در پشت کارهای دیگری که باید انجام شود تا مرورگر بهتر انجام شود، متوقف می شود. یک مثال عالی از این کار RenderingNG در Chromium است. این امر راه را برای اجرای زیرشبکه هموار کرده است. با این حال، شکاف طولانی بین فایرفاکس و زیرشبکه حمل و نقل کرومیوم به دلیل نیاز به طرح شبکه ای است که ابتدا در موتور رندر جدید دوباره پیاده سازی شود.

مشکلات

ما اینجا دو مشکل داریم. اولین مشکل قابلیت همکاری است، این واقعیت که از زمانی که یک ویژگی در یک مرورگر فرود می‌آید تا زمانی که در همه جا در دسترس است، زمان زیادی طول می‌کشد.

دوم مشکل پیام رسانی است. چگونه می توانیم مشخص کنیم که شکاف های پشتیبانی کجاست؟ چگونه ویژگی‌های جدید را به اشتراک می‌گذاریم بدون اینکه مجبور شویم همه به دقت درباره هر چیز تحقیق کنند تا بفهمند چقدر از آن پشتیبانی می‌شود؟

قابلیت همکاری

مرورگرها در حال حاضر با هم کار می کنند تا مشکل قابلیت همکاری را حل کنند. سال گذشته Compat 2021 به کاهش شکاف در پشتیبانی در تعدادی از ویژگی‌ها، از جمله ویژگی شکاف در طرح انعطاف‌پذیر کمک کرد. امسال تلاش Interop 2022 بر روی 15 ویژگی متمرکز شده است و قبلاً روی برخی از آنها حرکت هایی صورت گرفته است.

می توانید پیشرفت را در داشبورد Interop 2022 دنبال کنید.

پیام رسانی

مشکل دوم چیزی است که وقتی درباره ویژگی‌های اینجا در web.dev و developer.chrome.com صحبت می‌کنیم، مایلم به آن کمک کنم. می‌خواهم وقتی محتوای ما را می‌خوانید وضعیت ویژگی‌ها کاملاً واضح باشد و ما راه‌های عملی برای پیمایش مشکلات پشتیبانی ارائه دهیم.

ما تعدادی از دوره های اساسی را راه اندازی کرده ایم که در آینده بیشتر خواهد بود. این دوره ها به شما کمک می کند تا یاد بگیرید چگونه برای وب مدرن با استفاده از فناوری های اصلی پلت فرم وب بسازید. بررسی کنید:

ما در تلاش هستیم تا محتوای خود را در این سایت بر روی مواردی متمرکز کنیم که می توانید با خیال راحت از آنها استفاده کنید. ما هنوز به طور کامل به آنجا نرسیده ایم. با این حال، شما باید در ماه های آینده کمی تغییر به سمت عملی را مشاهده کنید.

ما همچنین از طریق پشتیبانی از پروژه Open Web Docs به باز کردن اسناد وب کمک می کنیم. این تضمین می کند که ما اسناد درجه یک در MDN را به همراه داده های به روز سازگاری مرورگر داریم. سپس از این داده ها در اینجا در web.dev برای نشان دادن پشتیبانی از ویژگی ها استفاده می کنیم. در اینجا پشتیبانی فعلی gap در طرح انعطاف پذیر است.

پشتیبانی مرورگر

  • کروم: 84.
  • لبه: 84.
  • فایرفاکس: 63.
  • سافاری: 14.1.

اگر می‌خواهید درباره چشم‌انداز Chrome برای وب، چیزهایی که در آزمایش‌های Origin و Developer آنها را آزمایش می‌کنیم، بیشتر بدانید، آن محتوا را به طور فزاینده‌ای در سایت خواهر ما - developer.chrome.com پیدا خواهید کرد. ممکن است محتوای آنجا آزمایشی باشد یا در حال حاضر فقط در Chrome پشتیبانی شود، اما ما دوست داریم آن را بررسی کنید و بازخورد ارائه دهید.

در حال حاضر واقعاً زمان هیجان انگیزی برای وب است. امیدواریم بتوانیم به شما کمک کنیم تا ویژگی‌های کلیدی را سریع‌تر به شما ارائه دهیم، و شکاف‌های موجود را روشن کنیم و توسعه وب را سرگرم‌کننده‌تر و کمتر خسته‌کننده کنیم.

عکس کریستوفر ماکسیمیلیان .