با لایه بالایی آشنا شوید: راه حلی برای z-index:10000

لایه بالایی بالای document مرتبط خود در نمای مرورگر قرار دارد و هر document دارای یک لایه بالای مرتبط است. این بدان معناست که عناصر ارتقا یافته به لایه بالایی نیازی به نگرانی در مورد z-index یا سلسله مراتب DOM ندارند. آنها همچنین یک شبه عنصر ::backdrop منظم برای بازی دریافت می کنند. مشخصات API تمام‌صفحه به جزئیات بیشتری می‌پردازد، زیرا تمام صفحه نمونه‌ای عالی از لایه بالایی بود که قبل از پشتیبانی dialog استفاده می‌شد.

لایه بالایی به حل مشکل ارائه محتوا در بالای بقیه document کمک می کند.

نکات مهمی که باید به خاطر بسپارید: - لایه بالایی خارج از جریان document است. - z-index هیچ تاثیری در لایه بالایی ندارد. - هر عنصر در لایه بالایی دارای یک شبه عنصر ::backdrop استایل پذیر است. - هر عنصر و ::backdrop یک زمینه انباشتگی جدید ایجاد می کند. - عناصر در لایه بالایی به ترتیبی که در مجموعه ظاهر می شوند روی هم چیده می شوند. آخرین مورد در، در بالا ظاهر می شود. اگر می خواهید عنصری را تبلیغ کنید، آن را حذف کرده و دوباره اضافه کنید.

چگونه لایه بالایی را تا به حال تقلید کرده ایم؟ خوب، دیدن توسعه دهندگانی که یک عنصر ظرف خالی را در انتهای body رها می کنند غیر معمول نیست. و سپس از این به عنوان یک لایه بالایی "faux" استفاده می شود. ایده این است که این ظرف بالاتر از هر چیز دیگری در پشته قرار می گیرد. وقتی می خواهید چیزی را بالاتر از هر چیز دیگری تبلیغ کنید، آن را به آن ظرف اضافه می کنید. ما می توانیم این را در بسته های محبوب مانند SweetAlert ، reactjs-popup ، Magnific Popup و موارد دیگر مشاهده کنیم.

با اجزای داخلی و APIهای جدید مانند <dialog> و "Popover" ، نیازی به متوسل شدن به این راه‌حل‌ها نخواهید داشت. می توانید محتوا را به لایه بالایی ارتقا دهید.

چارچوب‌های UI به ما امکان می‌دهند عناصر ارتقا یافته را با همتایان مؤلفه‌شان مکان‌یابی کنیم. اما، آنها اغلب در DOM هنگام رندر از هم جدا می شوند.

با استفاده از لایه بالایی، عناصر ارتقا یافته جایی هستند که آنها را در کد منبع خود قرار می دهید (به عنوان مثال، یک <dialog> ). مهم نیست که عنصر چند لایه در DOM است. به لایه بالایی ارتقا می‌یابد و می‌توانید آن را در جایی که انتظار دارید، با HTML جزء خود بررسی کنید. این کار بررسی همزمان عنصر ماشه و عنصر ارتقا یافته در DOM را آسان‌تر می‌کند. برای مثال اگر عنصر ماشه شما به‌روزرسانی ویژگی‌ها را انجام می‌دهد، بسیار مفید است. اکنون که المان ها در کنار هم قرار گرفته اند، این مزیت برای دسترسی نیز دارد.

برای نشان دادن لایه بالایی در مقابل z-index بالا، این نسخه نمایشی را در نظر بگیرید.

در این نسخه ی نمایشی، می توانید یک پاپ آپ SweetAlert را باز کنید و همچنین لایه بالایی <dialog> باز کنید. <dialog> را باز کنید و سپس پنجره SweetAlert را باز کنید. خواهید دید که در زیر عنصر لایه بالایی ما ظاهر می شود. و ریشه پنجره SweetAlert ما استفاده از z-index 10000 با position: fixed است.

.swal-overlay {
  z-index: 10000;
  position: fixed;
}

شما نیازی به اعمال هیچ سبکی در <dialog> ندارید تا آن را بالاتر از همه مطالب دیگر نشان دهید.

DevTools

و این ما را به پشتیبانی DevTools می رساند. Chrome DevTools از عناصر لایه بالایی پشتیبانی می‌کند تا بتوانید لایه بالایی را بررسی کنید. این کار اشکال زدایی و تجسم نحوه انباشته شدن چیزها در لایه بالایی یا حتی آنچه در لایه بالایی وجود دارد را آسان تر می کند.

GIF پشتیبانی از لایه بالایی DevTools نشان داده شده است

Alina Varkki مقاله ای عالی دارد که در مورد استفاده از این ابزارها به طور عمیق توضیح می دهد. آنها در حال حاضر به عنوان یک ویژگی پیش نمایش در Chrome Canary نسخه 105 در دسترس هستند.

همین!

معرفی مختصری از لایه بالایی. امکان گفتن "خداحافظ!" به مواردی مانند:

.popup-container {
  z-index: 10000;
}

چه چیزی را به لایه بالا فشار می دهید؟ آیا dialog را امتحان کرده اید؟ یا OpenUI Popover API را بررسی کرده اید؟ به ما اطلاع دهید!