CSS بسته بندی شده: 2023!، CSS بسته بندی شده: 2023!، CSS بسته بندی شده: 2023!

هدر پیچیده شده با CSS

CSS پیچیده شده: 2023!

وای! سال ۲۰۲۳ سال بزرگی برای CSS بود!

از #Interop2023 گرفته تا بسیاری از نوآوری‌های جدید در فضای CSS و رابط کاربری که قابلیت‌هایی را که توسعه‌دهندگان زمانی در پلتفرم وب غیرممکن می‌دانستند، فعال می‌کنند. اکنون، هر مرورگر مدرنی از کوئری‌های کانتینر، subgrid، انتخابگر :has() و مجموعه‌ای کامل از فضاها و توابع رنگی جدید پشتیبانی می‌کند. ما در کروم از انیمیشن‌های پیمایشی فقط CSS و انیمیشن روان بین نماهای وب با انتقال نماها پشتیبانی می‌کنیم. و علاوه بر همه اینها، بسیاری از عناصر اولیه جدید وجود دارند که برای تجربیات بهتر توسعه‌دهندگان مانند CSS nesting و سبک‌های scoped ارائه شده‌اند.

چه سالی بود! و ما دوست داریم این سال مهم را با تجلیل و قدردانی از تمام زحمات توسعه‌دهندگان مرورگر و جامعه وب که همه این‌ها را ممکن ساختند، به پایان برسانیم.

پایه‌های معماری

بیایید با به‌روزرسانی‌های زبان اصلی CSS و قابلیت‌های آن شروع کنیم. این‌ها ویژگی‌هایی هستند که برای نحوه‌ی نوشتن و سازماندهی استایل‌ها اساسی هستند و قدرت زیادی را در اختیار توسعه‌دهنده قرار می‌دهند.

توابع مثلثاتی

Browser Support

  • کروم: ۱۱۱.
  • لبه: ۱۱۱.
  • فایرفاکس: ۱۰۸.
  • سافاری: ۱۵.۴.

Source

کروم ۱۱۱ پشتیبانی از توابع مثلثاتی sin() ، cos() ، tan() ، asin() ، acos() ، atan() و atan2() را اضافه کرد و آنها را در تمام موتورهای اصلی در دسترس قرار داد. این توابع برای اهداف انیمیشن و طرح‌بندی بسیار مفید هستند. به عنوان مثال، اکنون چیدمان عناصر روی یک دایره به دور یک مرکز انتخاب شده بسیار آسان‌تر شده است.

نمایش توابع مثلثاتی

درباره توابع مثلثاتی در CSS بیشتر بدانید.

انتخاب مختلط n ام-*

Browser Support

  • کروم: ۱۱۱.
  • لبه: ۱۱۱.
  • فایرفاکس: ۱۱۳.
  • سافاری: ۹.

با استفاده از انتخابگر شبه کلاس :nth-child() می‌توان عناصر موجود در DOM را بر اساس اندیس آنها انتخاب کرد. با استفاده از ریزساختار An+B ، کنترل دقیقی بر روی عناصری که می‌خواهید انتخاب کنید، خواهید داشت.

به طور پیش‌فرض، شبه‌عملگرهای :nth-*() همه عناصر فرزند را در نظر می‌گیرند. از نسخه ۱۱۱ کروم، می‌توانید به صورت اختیاری، یک لیست انتخابگر را به :nth-child() و :nth-last-child() ارسال کنید. به این ترتیب می‌توانید قبل از اینکه An+B کار خود را انجام دهد، لیست فرزندان را از قبل فیلتر کنید.

در دموی زیر، منطق 3n+1 فقط روی عروسک‌های کوچک با پیش‌فیلتر کردن آنها با استفاده of .small اعمال می‌شود. از منوی کشویی برای تغییر پویای انتخابگر استفاده شده استفاده کنید.

نسخه آزمایشی انتخاب پیچیده n ام-*

درباره انتخاب‌های پیچیده n ام-* بیشتر بدانید.

محدوده

Browser Support

  • کروم: ۱۱۸.
  • لبه: ۱۱۸.
  • فایرفاکس: پشت یک پرچم.
  • سافاری: ۱۷.۴.

Source

کروم ۱۱۸ پشتیبانی از @scope ، یک at-rule، را اضافه کرد که به شما امکان می‌دهد انتخابگر scope را با یک زیرشاخه خاص از سند تطبیق دهید. با استایل‌بندی scoped، می‌توانید در مورد عناصری که انتخاب می‌کنید بسیار دقیق باشید، بدون اینکه مجبور باشید انتخابگرهای بیش از حد خاص بنویسید یا آنها را به ساختار DOM محکم متصل کنید.

یک زیردرختِ دارای محدوده، توسط یک ریشه‌ی محدوده (مرز بالایی) و یک حد محدوده‌ی اختیاری (مرز پایینی) تعریف می‌شود.

@scope (.card) {  } /* scoping root */
@scope (.card) to (.card__content) {  } /* scoping root + scoping limit*/

قوانین سبک‌دهی که درون یک بلوک scope قرار می‌گیرند، فقط عناصر درون زیردرخت جدا شده را هدف قرار می‌دهند. برای مثال، قانون سبک‌دهی scoped زیر فقط عناصر <img> را که بین عنصر .card و هر کامپوننت تودرتو که با انتخابگر [data-component] مطابقت دارد، قرار می‌گیرند، هدف قرار می‌دهد.

@scope (.card) to ([data-component]) {
  img {  }
}

در دموی زیر، عناصر <img> در کامپوننت carousel به دلیل محدودیت دامنه اعمال شده، تطبیق داده نمی‌شوند.

تصویر نمایشی Scope

Reference screenshot for the @scope demo

نسخه آزمایشی زنده Scope

نسخه آزمایشی CSS @scope

برای کسب اطلاعات بیشتر در مورد @scope به مقاله "چگونه از @scope برای محدود کردن دسترسی انتخابگرهای خود استفاده کنیم" مراجعه کنید. در این مقاله در مورد انتخابگر :scope ، نحوه مدیریت ویژگی خاص، محدوده‌های بدون مقدمه و نحوه تأثیر @scope بر آبشار یاد خواهید گرفت.

لانه سازی

Browser Support

  • کروم: ۱۲۰.
  • لبه: ۱۲۰.
  • فایرفاکس: ۱۱۷.
  • سافاری: ۱۷.۲.

Source

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

dl {
  /* dt styles */
  
  dt {
    /* dl dt styles */
  }

  dd {
    /* dl dd styles */
  }
}

/* same as */
dt {
  /* dt styles */
}

dl dt {
  /* dl dt styles */
}

dl dd {
  /* dl dd styles */
}

اسکرین‌کست تودرتو

نسخه آزمایشی زنده تودرتو

انتخابگر تودرتوی آرام را تغییر دهید تا برنده مسابقه مشخص شود

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

درباره لانه سازی بیشتر بدانید.

زیرشبکه

Browser Support

  • کروم: ۱۱۷.
  • لبه: ۱۱۷.
  • فایرفاکس: ۷۱.
  • سافاری: ۱۶.

Source

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

اسکرین‌کست زیرشبکه‌ای

نسخه آزمایشی زنده سابگرید

سربرگ، بدنه و پاورقی‌ها با اندازه‌های پویای عناصر مشابه خود هم‌تراز می‌شوند.

زیرشبکه (Subgrid) به ویژه برای تراز کردن بخش‌های مشابه با محتوای پویای یکدیگر مفید است. این امر نویسندگان محتوا، نویسندگان تجربه کاربری و مترجمان را از تلاش برای ایجاد نسخه‌ای از پروژه که "با طرح‌بندی" مطابقت داشته باشد، بی‌نیاز می‌کند. با زیرشبکه، طرح‌بندی را می‌توان طوری تنظیم کرد که با محتوا متناسب باشد.

درباره زیرشبکه بیشتر بدانید.

تایپوگرافی

تایپوگرافی وب در سال ۲۰۲۳ چند به‌روزرسانی کلیدی را تجربه کرد. یکی از پیشرفت‌های تدریجی و به‌خصوص خوب، ویژگی text-wrap است. این ویژگی امکان تنظیم طرح‌بندی تایپوگرافی را فراهم می‌کند که در مرورگر و بدون نیاز به اسکریپت‌نویسی اضافی ایجاد می‌شود. با طول خطوط نامناسب خداحافظی کنید و به تایپوگرافی قابل پیش‌بینی‌تر سلام کنید!

حرف اول اسم

Browser Support

  • کروم: ۱۱۰.
  • لبه: ۱۱۰.
  • فایرفاکس: پشتیبانی نمی‌شود.
  • سافاری: ۹.

Source

ویژگی initial-letter که در ابتدای سال در کروم ۱۱۰ معرفی شد، یک ویژگی کوچک اما قدرتمند CSS است که استایل قرارگیری حروف اولیه را تنظیم می‌کند. می‌توانید حروف را در حالت افتاده یا برآمده قرار دهید. این ویژگی دو آرگومان می‌پذیرد: اولی برای اینکه حرف چقدر در پاراگراف مربوطه قرار گیرد و دومی برای اینکه حرف چقدر بالاتر از آن قرار گیرد. حتی می‌توانید ترکیبی از هر دو را انجام دهید، مانند دموی زیر.

تصویر با حرف اول اسم

تصویر نمایشی با حرف اول اسم

نسخه آزمایشی حروف اول

مقادیر initial-letter را برای شبه عنصر ::first-letter تغییر دهید تا تغییر آن را مشاهده کنید.

درباره حرف اول اسم (initial-letter) بیشتر بدانید.

متن-پیچیده: تعادل و زیبایی

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

اینجاست که دو تکنیک جدید برای چیدمان متن وارد می‌شوند، یکی balance و دیگری pretty . مقدار balance به دنبال ایجاد یک بلوک متن هماهنگ است در حالی که pretty به دنبال جلوگیری از یتیم شدن و اطمینان از خط فاصله‌گذاری سالم است. هر دوی این وظایف به طور سنتی با دست انجام می‌شدند، و شگفت‌انگیز است که این کار را به مرورگر واگذار کنیم و آن را برای هر زبان ترجمه شده‌ای به کار بگیریم.

اسکرین‌شات با قابلیت پوشش متن

نسخه آزمایشی زنده Text-wrap

در دموی زیر می‌توانید با کشیدن اسلایدر، اثرات balance و pretty روی یک عنوان و یک پاراگراف مقایسه کنید. سعی کنید دمو را به زبان دیگری ترجمه کنید!

درباره text-wrap: balance بیشتر بدانید.

رنگ

سال ۲۰۲۳ سال رنگ برای پلتفرم وب بود. با فضاهای رنگی جدید و عملکردهایی که امکان تم‌بندی رنگی پویا را فراهم می‌کنند، هیچ چیز مانع شما از ایجاد تم‌های زنده و باشکوهی که کاربرانتان شایسته آن هستند، و همچنین قابل تنظیم کردن آنها نخواهد شد!

فضاهای رنگی HD (سطح رنگ ۴)

Browser Support

  • کروم: ۱۱۱.
  • لبه: ۱۱۱.
  • فایرفاکس: ۱۱۳.
  • سافاری: ۱۵.

Source

Browser Support

  • کروم: ۱۱۱.
  • لبه: ۱۱۱.
  • فایرفاکس: ۱۱۳.
  • سافاری: ۱۵.

Source

از سخت‌افزار گرفته تا نرم‌افزار، از CSS گرفته تا چراغ‌های چشمک‌زن؛ برای اینکه رایانه‌های ما تلاش کنند رنگ‌ها را به خوبی آنچه چشم انسان می‌تواند ببیند، نمایش دهند، می‌تواند کار زیادی لازم باشد. در سال ۲۰۲۳، ما رنگ‌های جدید، رنگ‌های بیشتر، فضاهای رنگی جدید، توابع رنگی و قابلیت‌های جدید خواهیم داشت.

CSS و رنگ اکنون می‌توانند: - بررسی کنند که آیا سخت‌افزار صفحه نمایش کاربر قادر به پشتیبانی از رنگ‌های HDR با طیف وسیع است یا خیر. - بررسی کنند که آیا مرورگر کاربر سینتکس رنگ مانند Oklch یا Display P3 را درک می‌کند یا خیر. - رنگ‌های HDR را در Oklab، Oklch، HWB، Display P3، Rec.2020، XYZ و موارد دیگر مشخص کنند. - با رنگ‌های HDR گرادیان ایجاد کنند، - گرادیان‌ها را در فضاهای رنگی جایگزین درون‌یابی کنند. - رنگ‌ها را با color-mix() ترکیب کنند. - انواع رنگ را با سینتکس رنگ نسبی ایجاد کنند.

اسکرین‌کست رنگی ۴

نسخه آزمایشی رنگ ۴

در دموی زیر می‌توانید با کشیدن اسلایدر، اثرات «balance» و «pretty» را روی یک عنوان و یک پاراگراف مقایسه کنید. سعی کنید دمو را به زبان دیگری ترجمه کنید!

درباره رنگ ۴ و فضاهای رنگی بیشتر بدانید.

تابع ترکیب رنگ

Browser Support

  • کروم: ۱۱۱.
  • لبه: ۱۱۱.
  • فایرفاکس: ۱۱۳.
  • سافاری: ۱۶.۲.

Source

ترکیب رنگ یک کار کلاسیک است و در سال ۲۰۲۳ CSS نیز می‌تواند این کار را انجام دهد. شما نه تنها می‌توانید رنگ سفید یا سیاه را با یک رنگ ترکیب کنید، بلکه می‌توانید شفافیت را نیز تغییر دهید و همه این کارها را در هر فضای رنگی دلخواه خود انجام دهید. این همزمان یک ویژگی رنگ پایه و یک ویژگی رنگ پیشرفته است.

ترکیب رنگ ()

ترکیب رنگ () نسخه آزمایشی

نسخه آزمایشی به شما این امکان را می‌دهد که با استفاده از یک انتخابگر رنگ، دو رنگ، فضای رنگی و میزان غالب بودن هر رنگ در ترکیب را انتخاب کنید.

می‌توانید color-mix() را به عنوان یک لحظه از یک گرادیان در نظر بگیرید. در حالی که گرادیان تمام مراحل لازم برای رفتن از آبی به سفید را نشان می‌دهد، color-mix() فقط یک مرحله را نشان می‌دهد. وقتی شروع به در نظر گرفتن فضاهای رنگی کنید و یاد بگیرید که ترکیب فضای رنگی چقدر می‌تواند با نتایج متفاوت باشد، همه چیز پیشرفته‌تر می‌شود.

درباره تابع color-mix() بیشتر بدانید.

نحو رنگ نسبی

سینتکس رنگ نسبی (RCS) یک روش مکمل برای color-mix() برای ایجاد انواع رنگ است. این روش کمی قدرتمندتر از color-mix() است، اما همچنین یک استراتژی متفاوت برای کار با رنگ است. color-mix() ممکن است رنگ سفید را برای روشن‌تر کردن یک رنگ ترکیب کند، در حالی که RCS دسترسی دقیق به کانال روشنایی و امکان استفاده از calc() در کانال را برای کاهش یا افزایش روشنایی به صورت برنامه‌نویسی شده فراهم می‌کند.

اسکرین‌کست RCS

نسخه آزمایشی زنده RCS

رنگ را تغییر دهید، صحنه‌ها را تغییر دهید. هر کدام از آن‌ها از سینتکس رنگ نسبی برای ایجاد انواع رنگ پایه استفاده می‌کنند.

RCS به شما امکان می‌دهد تا دستکاری‌های نسبی و مطلق را روی یک رنگ انجام دهید. تغییر نسبی زمانی است که مقدار فعلی اشباع یا روشنایی را گرفته و آن را با calc() تغییر می‌دهید. تغییر مطلق زمانی است که مقدار یک کانال را با مقدار کاملاً جدیدی جایگزین می‌کنید، مانند تنظیم opacity روی ۵۰٪. این سینتکس ابزارهای معناداری برای تم‌بندی، انواع just in time و موارد دیگر در اختیار شما قرار می‌دهد.

درباره سینتکس رنگ نسبی بیشتر بدانید.

طراحی واکنش‌گرا

طراحی واکنش‌گرا (Responsive) در سال ۲۰۲۳ تکامل یافت. این سال پیشگامانه، ویژگی‌های جدیدی را فراهم کرد که به طور کامل نحوه ساخت تجربیات وب واکنش‌گرا را تغییر می‌دهد و مدل جدیدی از طراحی واکنش‌گرا مبتنی بر کامپوننت را معرفی کرد. ترکیب کوئری‌های کانتینر و :has() از کامپوننت‌هایی پشتیبانی می‌کند که سبک‌بندی واکنش‌گرا و منطقی خود را بر اساس اندازه والد خود و همچنین وجود یا وضعیت هر یک از فرزندانشان دارند. این بدان معناست که بالاخره می‌توانید طرح‌بندی سطح صفحه را از طرح‌بندی سطح کامپوننت جدا کنید و منطق را یک بار بنویسید تا از کامپوننت خود در همه جا استفاده کنید!

سوالات مربوط به اندازه کانتینر

Browser Support

  • کروم: ۱۰۵.
  • لبه: ۱۰۵.
  • فایرفاکس: ۱۱۰.
  • سافاری: ۱۶.

Source

به جای استفاده از اطلاعات اندازه سراسری viewport برای اعمال سبک‌های CSS، کوئری‌های container از کوئری گرفتن از یک عنصر والد در صفحه پشتیبانی می‌کنند. این بدان معناست که کامپوننت‌ها می‌توانند به صورت پویا در چندین طرح‌بندی و در چندین نما استایل‌دهی شوند. کوئری‌های container برای اندازه در روز ولنتاین امسال (۱۴ فوریه) در تمام مرورگرهای مدرن پایدار شدند.

برای استفاده از این ویژگی، ابتدا محدودیت را روی عنصری که کوئری می‌کنید تنظیم کنید و سپس، مشابه یک کوئری رسانه‌ای، @container به همراه پارامترهای اندازه برای اعمال استایل‌ها استفاده کنید. همراه با کوئری‌های کانتینر، اندازه‌های کوئری کانتینر را نیز دریافت می‌کنید. در دموی زیر، از اندازه کوئری کانتینر cqi (که نشان‌دهنده اندازه کانتینر درون‌خطی است) برای تعیین اندازه هدر کارت استفاده می‌شود.

@container اسکرین‌شات

نسخه آزمایشی @container

درباره استفاده از پرس‌وجوهای کانتینر بیشتر بدانید.

کوئری‌های مربوط به کانتینر استایل

Browser Support

  • کروم: ۱۱۱.
  • لبه: ۱۱۱.
  • فایرفاکس: پشتیبانی نمی‌شود.
  • سافاری: ۱۸.

کوئری‌های استایل با پیاده‌سازی جزئی در کروم ۱۱۱ ارائه شدند. با کوئری‌های استایل فعلی، می‌توانید هنگام استفاده از @container style() مقدار ویژگی‌های سفارشی را روی یک عنصر والد جستجو کنید. برای مثال، بررسی کنید که آیا مقدار ویژگی سفارشی وجود دارد یا روی مقدار خاصی تنظیم شده است، مانند @container style(--rain: true) .

تصویر پرس و جو سبک

تصویر نمایشی برای نمایش سبک کانتینرها، کارت‌های آب و هوا

نسخه آزمایشی پرس و جو سبک

رنگ را تغییر دهید، صحنه‌ها را تغییر دهید. هر کدام از آن‌ها از سینتکس رنگ نسبی برای ایجاد انواع رنگ پایه استفاده می‌کنند.

اگرچه این شبیه به استفاده از نام کلاس در CSS به نظر می‌رسد، اما کوئری‌های استایل مزایایی دارند. اولین مزیت این است که با کوئری‌های استایل، می‌توانید مقدار را در CSS در صورت نیاز برای حالت‌های کاذب به‌روزرسانی کنید. همچنین، در نسخه‌های بعدی پیاده‌سازی، می‌توانید محدوده‌هایی از مقادیر را برای تعیین استایل اعمال شده، مانند style(60 <= --weather <= 70) و استایل مبتنی بر جفت‌های ویژگی-مقدار مانند style(font-style: italic) کوئری کنید.

درباره استفاده از کوئری‌های استایل بیشتر بدانید.

انتخابگر has() :

Browser Support

  • کروم: ۱۰۵.
  • لبه: ۱۰۵.
  • فایرفاکس: ۱۲۱.
  • سافاری: ۱۵.۴.

Source

تقریباً 20 سال است که توسعه‌دهندگان درخواست وجود یک "انتخابگر والد" در CSS را داشته‌اند. با انتخابگر :has() که در کروم 105 ارائه شد، اکنون این امر امکان‌پذیر است. برای مثال، استفاده از .card:has(img.hero) ‎ عناصر .card ‎ را که دارای تصویر قهرمان به عنوان فرزند هستند، انتخاب می‌کند.

:has() تصویر نمایشی

Reference screenshot for the :has() demo

:has() نسخه آزمایشی زنده

CSS :has() نسخه آزمایشی: کارت بدون/با تصویر

از آنجا که :has() یک لیست انتخابگر نسبی را به عنوان آرگومان خود می‌پذیرد، می‌توانید عناصر بسیار بیشتری را علاوه بر عنصر والد انتخاب کنید. با استفاده از ترکیب‌کننده‌های مختلف CSS، نه تنها می‌توان در درخت DOM به سمت بالا حرکت کرد، بلکه می‌توان انتخاب‌های جانبی نیز انجام داد. برای مثال، li:has(+ li:hover) عنصر <li> را که قبل از عنصر <li> که در حال حاضر موس روی آن قرار دارد، قرار دارد، انتخاب می‌کند.

:has() اسکرین‌شات

:has() نسخه آزمایشی

CSS :has() نسخه آزمایشی: داک

درباره انتخابگر :has() در CSS بیشتر بدانید.

به‌روزرسانی پرس‌وجوی رسانه

Browser Support

  • کروم: ۱۱۳.
  • لبه: ۱۱۳.
  • فایرفاکس: ۱۰۲.
  • سافاری: ۱۷.

Source

کوئری update رسانه به شما روشی برای تطبیق رابط کاربری با نرخ تازه‌سازی یک دستگاه می‌دهد. این ویژگی می‌تواند مقداری از نوع fast ، slow یا none را گزارش دهد که مربوط به قابلیت‌های دستگاه‌های مختلف است.

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

به‌روزرسانی اسکرین‌کست

نسخه آزمایشی را به‌روزرسانی کنید

(با انتخاب یک گزینه رادیویی) یک مقدار سرعت به‌روزرسانی را شبیه‌سازی کنید و ببینید که چگونه بر اردک تأثیر می‌گذارد.

درباره @media بیشتر بدانید (به‌روزرسانی) .

اسکریپت نویسی پرس و جو رسانه ای

Browser Support

  • کروم: ۱۲۰.
  • لبه: ۱۲۰.
  • فایرفاکس: ۱۱۳.
  • سافاری: ۱۷.

Source

می‌توان از کوئری رسانه‌ای اسکریپت‌نویسی برای بررسی وجود یا عدم وجود جاوا اسکریپت استفاده کرد. این برای بهبود تدریجی بسیار خوب است. قبل از این کوئری رسانه‌ای، یک استراتژی برای تشخیص وجود جاوا اسکریپت، قرار دادن یک کلاس nojs در HTML و حذف آن با جاوا اسکریپت بود. این اسکریپت‌ها را می‌توان حذف کرد زیرا CSS اکنون راهی برای تشخیص جاوا اسکریپت و تنظیم متناسب با آن دارد.

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

اسکریپت نویسی

نسخه آزمایشی اسکریپت نویسی

تغییر تم در یک وب‌سایت را در نظر بگیرید، کوئری رسانه اسکریپت‌نویسی می‌تواند به کار کردن این تغییر در برابر تنظیمات سیستم کمک کند زیرا جاوا اسکریپتی در دسترس نیست. یا یک کامپوننت سوئیچ را در نظر بگیرید - اگر جاوا اسکریپت در دسترس باشد، می‌توان سوئیچ را با یک حرکت کشید، نه اینکه فقط روشن و خاموش شود. اگر اسکریپت‌نویسی در دسترس باشد، فرصت‌های عالی زیادی برای ارتقاء UX وجود دارد، در حالی که اگر اسکریپت‌نویسی غیرفعال باشد، یک تجربه پایه معنادار ارائه می‌شود.

درباره اسکریپت بیشتر بدانید.

پرس و جوی رسانه‌ای با شفافیت کاهش‌یافته

Browser Support

  • کروم: ۱۱۸.
  • لبه: ۱۱۸.
  • فایرفاکس: پشت یک پرچم.
  • سافاری: پشتیبانی نمی‌شود.

Source

رابط‌های کاربری غیرشفاف می‌توانند باعث سردرد یا مشکل بینایی برای انواع مختلف نقص‌های بینایی شوند. به همین دلیل است که ویندوز، macOS و iOS تنظیمات سیستمی دارند که می‌توانند شفافیت را از رابط کاربری کاهش یا حذف کنند. این کوئری رسانه‌ای برای prefers-reduced-transparency به خوبی با سایر کوئری‌های رسانه‌ای preferences مطابقت دارد، که به شما امکان می‌دهد خلاق باشید و در عین حال برای کاربران تنظیم کنید.

کاهش شفافیت در ضبط صفحه نمایش

نسخه آزمایشی شفافیت کاهش‌یافته

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

درباره @media (ترجیحاً شفافیت کاهش‌یافته) بیشتر بدانید.

تعامل

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

مشاهده انتقال‌ها

Browser Support

  • کروم: ۱۱۱.
  • لبه: ۱۱۱.
  • فایرفاکس: ۱۴۴.
  • سافاری: ۱۸.

Source

انتقال‌های نمایشی (View Transitions) تأثیر زیادی بر تجربه کاربری یک صفحه دارند. با استفاده از API انتقال‌های نمایشی (View Transitions API)، می‌توانید انتقال‌های بصری بین دو حالت صفحه از برنامه تک صفحه‌ای خود ایجاد کنید. این انتقال‌ها می‌توانند انتقال‌های کل صفحه یا موارد کوچک‌تر در یک صفحه مانند اضافه کردن یا حذف یک مورد جدید به یک لیست باشند.

در هسته‌ی API مربوط به View Transitions، تابع document.startViewTranstion قرار دارد. تابعی را به آن ارسال کنید که DOM را به حالت جدید به‌روزرسانی می‌کند و API همه چیز را برای شما انجام می‌دهد. این API این کار را با گرفتن یک snapshot قبل و بعد و سپس انتقال بین این دو انجام می‌دهد. با استفاده از CSS می‌توانید کنترل کنید که چه چیزی ثبت شود و به صورت اختیاری نحوه‌ی انیمیشن‌سازی این snapshotها را سفارشی کنید.

اسکرین‌کست VT

نسخه آزمایشی VT

مشاهده نسخه نمایشی انتقال‌ها

رابط برنامه‌نویسی کاربردی View Transitions برای برنامه‌های تک‌صفحه‌ای در کروم ۱۱۱ ارائه شد. درباره View Transitions بیشتر بدانید.

تابع کاهش خطی

Browser Support

  • کروم: ۱۱۳.
  • لبه: ۱۱۳.
  • فایرفاکس: ۱۱۲.
  • سافاری: ۱۷.۲.

Source

نگذارید اسم این تابع شما را فریب دهد. تابع linear() (نباید با کلمه کلیدی linear اشتباه گرفته شود) به شما امکان می‌دهد توابع easing پیچیده را به روشی ساده ایجاد کنید، البته با این تفاوت که مقداری از دقت خود را از دست می‌دهید.

قبل از linear() که در کروم ۱۱۳ ارائه شد، ایجاد جلوه‌های پرش یا فنر در CSS غیرممکن بود. به لطف linear() می‌توان این easings را با ساده‌سازی آنها به مجموعه‌ای از نقاط و سپس درون‌یابی خطی بین این نقاط، تقریب زد.

Chart of a bounce easing curve with several dots added to it
منحنی پرش اصلی که با رنگ آبی نشان داده شده است، توسط مجموعه‌ای از نقاط کلیدی که با رنگ سبز نشان داده شده‌اند، ساده‌سازی شده است. تابع linear() از این نقاط استفاده کرده و به صورت خطی بین آنها درون‌یابی می‌کند.

اسکرین‌شات با کاهش خطی

نسخه آزمایشی کاهش خطی

نسخه آزمایشی تابع linear() در CSS

درباره linear() بیشتر بدانید. برای ایجاد منحنی‌های linear() ، از مولد linear easing استفاده کنید.

پایان اسکرول

Browser Support

  • کروم: ۱۱۴.
  • لبه: ۱۱۴.
  • فایرفاکس: ۱۰۹.
  • پیش‌نمایش فناوری سافاری: پشتیبانی می‌شود.

Source

بسیاری از رابط‌ها شامل تعاملات اسکرول هستند و گاهی اوقات رابط نیاز به همگام‌سازی اطلاعات مربوط به موقعیت اسکرول فعلی یا دریافت داده‌ها بر اساس وضعیت فعلی دارد. قبل از رویداد scrollend ، شما مجبور بودید از یک متد timeout نادرست استفاده کنید که می‌توانست در حالی که انگشت کاربر هنوز روی صفحه بود، اجرا شود. با رویداد scrollend ، شما یک رویداد scrollend با زمان‌بندی کاملاً دقیق دارید که می‌فهمد آیا کاربر هنوز در حال انجام حرکت است یا خیر.

اسکرول اند اسکرین‌کست

نسخه آزمایشی اسکرول

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

درباره اسکرولند بیشتر بدانید.

انیمیشن‌های اسکرول‌محور

Browser Support

  • کروم: ۱۱۵.
  • لبه: ۱۱۵.
  • فایرفاکس: پشت یک پرچم.
  • سافاری: ۲۶.

Source

انیمیشن‌های اسکرول‌محور یک ویژگی هیجان‌انگیز هستند که از کروم ۱۱۵ در دسترس قرار گرفته‌اند. این انیمیشن‌ها به شما امکان می‌دهند یک انیمیشن CSS موجود یا یک انیمیشن ساخته شده با Web Animations API را انتخاب کنید و آن را به آفست اسکرول یک اسکرول‌کننده متصل کنید. همانطور که در یک اسکرول‌کننده افقی به بالا و پایین - یا چپ و راست - اسکرول می‌کنید، انیمیشن لینک‌شده در پاسخ مستقیم به جلو و عقب حرکت می‌کند.

با ScrollTimeline می‌توانید پیشرفت کلی یک scroller را پیگیری کنید، همانطور که در دموی زیر نشان داده شده است. همانطور که به انتهای صفحه اسکرول می‌کنید، متن کاراکتر به کاراکتر خود را نشان می‌دهد.

اسکرین‌شات SDA

نسخه آزمایشی SDA

نسخه نمایشی انیمیشن‌های اسکرول محور CSS: اسکرول تایم‌لاین

با استفاده از ViewTimeline می‌توانید یک عنصر را هنگام عبور از scrollport ردیابی کنید. این کار مشابه نحوه ردیابی یک عنصر توسط IntersectionObserver است. در دموی زیر، هر تصویر از لحظه ورود به scrollport تا زمانی که در مرکز قرار می‌گیرد، خود را نشان می‌دهد.

نسخه آزمایشی SDA از صفحه نمایش

نسخه آزمایشی زنده SDA

نسخه نمایشی انیمیشن‌های اسکرول محور CSS: مشاهده جدول زمانی

از آنجایی که انیمیشن‌های اسکرول‌محور با انیمیشن‌های CSS و API انیمیشن‌های وب کار می‌کنند، می‌توانید از تمام مزایایی که این APIها ارائه می‌دهند، بهره‌مند شوید. این شامل قابلیت اجرای این انیمیشن‌ها در thread اصلی نیز می‌شود. اکنون می‌توانید انیمیشن‌های روان و ابریشمی داشته باشید که توسط اسکرول هدایت می‌شوند و تنها با چند خط کد اضافی از thread اصلی اجرا می‌شوند - چه چیزی دوست داشتنی نیست؟

برای کسب اطلاعات بیشتر در مورد انیمیشن‌های اسکرول-راندمان ، این مقاله را با تمام جزئیات بررسی کنید یا از scroll-driven-animations.style که شامل دموهای زیادی است، دیدن کنید .

پیوست جدول زمانی معوق

Browser Support

  • کروم: ۱۱۶.
  • لبه: ۱۱۶.
  • فایرفاکس: پشتیبانی نمی‌شود.
  • سافاری: ۲۶.

Source

هنگام اعمال یک انیمیشن اسکرول-محور از طریق CSS، مکانیزم جستجو برای یافتن اسکرول‌کننده‌ی کنترل‌کننده، همیشه در درخت DOM بالا می‌رود و این باعث می‌شود که فقط به اجداد اسکرول محدود شود. با این حال، اغلب اوقات، عنصری که باید متحرک‌سازی شود، فرزند اسکرول‌کننده نیست، بلکه عنصری است که در یک زیردرخت کاملاً متفاوت قرار دارد.

برای اینکه عنصر متحرک بتواند یک scroll-timeline نام‌گذاری شده از یک عنصر غیر اجدادی را پیدا کند، از ویژگی timeline-scope در یک والد مشترک استفاده کنید. این کار به scroll-timeline یا view-timeline تعریف شده با آن نام اجازه می‌دهد تا به آن متصل شود و دامنه وسیع‌تری به آن بدهد. با این کار، هر فرزندی از آن والد مشترک می‌تواند از جدول زمانی با آن نام استفاده کند.

Visualization of a DOM subtree with timeline-scope used on a shared parent
با تعریف timeline-scope در والد مشترک، scroll-timeline تعریف شده در scroller را می‌توان توسط عنصری که از آن به عنوان animation-timeline خود استفاده می‌کند، پیدا کرد.

نسخه آزمایشی اسکرین‌کست

نسخه آزمایشی زنده

نسخه نمایشی انیمیشن‌های اسکرول محور CSS: پیوست جدول زمانی معوق

درباره timeline-scope بیشتر بدانید.

انیمیشن‌های ویژگی‌های گسسته

یکی دیگر از قابلیت‌های جدید در سال ۲۰۲۳، امکان متحرک‌سازی انیمیشن‌های گسسته، مانند متحرک‌سازی به و از display: none است. از کروم ۱۱۶، می‌توانید از display و content-visibility در قوانین keyframe استفاده کنید. همچنین می‌توانید هر ویژگی گسسته را در نقطه ۵۰٪ به جای نقطه ۰٪ منتقل کنید. این کار با ویژگی transition-behavior با استفاده از کلمه کلیدی allow-discrete یا در ویژگی transition به عنوان یک میانبر انجام می‌شود.

انیمیشن گسسته. اسکرین‌کست

انیمیشن گسسته. نسخه آزمایشی

درباره انتقال انیمیشن‌های گسسته بیشتر بدانید.

@سبک-شروع

Browser Support

  • کروم: ۱۱۷.
  • لبه: ۱۱۷.
  • فایرفاکس: ۱۲۹.
  • سافاری: ۱۷.۵

Source

قانون CSS @starting-style بر اساس قابلیت‌های جدید وب برای انیمیشن به و از display: none . این قانون راهی را برای دادن یک سبک "قبل از باز شدن" به یک عنصر فراهم می‌کند که مرورگر می‌تواند قبل از باز شدن عنصر در صفحه، آن را جستجو کند. این برای انیمیشن‌های ورودی و برای انیمیشن در عناصری مانند پنجره بازشو یا کادر محاوره‌ای بسیار مفید است. همچنین می‌تواند برای هر زمانی که یک عنصر ایجاد می‌کنید و می‌خواهید به آن قابلیت انیمیشن بدهید، مفید باشد. مثال زیر را در نظر بگیرید که یک ویژگی popover (به بخش بعدی مراجعه کنید) را به صورت روان از خارج از پنجره نمایش به نمای و به لایه بالایی منتقل می‌کند.

@شروع-سبک ضبط صفحه نمایش

نسخه آزمایشی @starting-style

درباره @starting-style و سایر انیمیشن‌های ورودی بیشتر بدانید.

روکش

Browser Support

  • کروم: ۱۱۷.
  • لبه: ۱۱۷.
  • فایرفاکس: پشتیبانی نمی‌شود.
  • سافاری: پشتیبانی نمی‌شود.

Source

ویژگی جدید CSS overlay را می‌توان به transition شما اضافه کرد تا عناصری که سبک‌های لایه بالایی دارند - مانند popover و dialog - بتوانند به راحتی از لایه بالایی خارج شوند. اگر transition overlay را فعال نکنید، عنصر شما بلافاصله به حالت برش، تبدیل و پوشانده شدن برمی‌گردد و شما شاهد وقوع transition نخواهید بود. به طور مشابه، overlay ::backdrop را قادر می‌سازد تا هنگام اضافه شدن به یک عنصر لایه بالایی، به آرامی خارج شود.

روکش صفحه نمایش

نسخه آزمایشی زنده

درباره پوشش و سایر انیمیشن‌های خروج بیشتر بدانید.

قطعات

سال ۲۰۲۳ سال بزرگی برای تلاقی استایل و کامپوننت‌های HTML بود، با فرود popover و کارهای زیادی که در مورد موقعیت‌یابی anchor و آینده‌ی منوی‌های کشویی استایل‌دهی انجام شد. این کامپوننت‌ها ساخت الگوهای رابط کاربری رایج را بدون نیاز به تکیه بر کتابخانه‌های اضافی یا ساخت سیستم‌های مدیریت حالت خودتان از صفر در هر بار، آسان‌تر می‌کنند.

پاپ‌اوور

Browser Support

  • کروم: ۱۱۴.
  • لبه: ۱۱۴.
  • فایرفاکس: ۱۲۵.
  • سافاری: ۱۷.

Source

API مربوط به Popover به شما کمک می‌کند تا عناصری بسازید که روی بقیه صفحه قرار می‌گیرند. این عناصر می‌توانند شامل منوها، انتخاب‌ها و راهنماهای ابزار باشند. می‌توانید با اضافه کردن ویژگی popover و یک id به عنصری که ظاهر می‌شود و اتصال ویژگی id آن به یک دکمه فراخوانی با استفاده از popovertarget="my-popover" یک popover ساده ایجاد کنید. API مربوط به Popover از موارد زیر پشتیبانی می‌کند:

  • ارتقاء به لایه بالا. پاپ‌اوورها در یک لایه جداگانه بالای بقیه صفحه ظاهر می‌شوند، بنابراین لازم نیست با z-index بازی کنید.
  • قابلیت حذف نور. کلیک کردن در خارج از ناحیه‌ی بازشو، بازشو را می‌بندد و فوکوس را برمی‌گرداند.
  • مدیریت فوکوس پیش‌فرض. باز کردن پنجره‌ی پاپ‌اوور باعث می‌شود تب بعدی درون پنجره‌ی پاپ‌اوور متوقف شود.
  • پیوندهای صفحه کلید قابل دسترسی. فشردن کلید esc یا دوبار فشردن همزمان کلیدها، پنجره‌ی بازشو را می‌بندد و فوکوس را برمی‌گرداند.
  • اتصال کامپوننت‌های قابل دسترس. اتصال یک عنصر popover به یک تریگر popover از نظر معنایی.

پخش زنده از صفحه نمایش

نسخه آزمایشی زنده Popover

قوانین افقی در select

یکی دیگر از تغییرات کوچک HTML که امسال در کروم و سافاری اعمال شد، امکان اضافه کردن عناصر خط افقی (تگ‌های <hr> ) به عناصر <select> است تا به تفکیک بصری محتوای شما کمک کند. پیش از این، قرار دادن یک تگ <hr> در یک select به سادگی رندر نمی‌شد. اما امسال، هم سافاری و هم کروم از این ویژگی پشتیبانی می‌کنند و امکان جداسازی بهتر محتوا در عناصر <select> را فراهم می‌کنند.

انتخاب تصویر صفحه

اسکرین شات از hr در select با تم روشن و تیره در کروم

نسخه آزمایشی زنده را انتخاب کنید

درباره استفاده از using hr در select بیشتر بدانید

:کلاس‌های شبه معتبر برای کاربر و نامعتبر

Browser Support

  • کروم: ۱۱۹.
  • لبه: ۱۱۹.
  • فایرفاکس: ۸۸.
  • سافاری: ۱۶.۵

Source

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

با این انتخابگرهای جدید، دیگر نیازی به نوشتن کد stateful برای پیگیری ورودی‌هایی که کاربر تغییر داده است، نیست.

:کاربر-* اسکرین‌کست

:user-* نسخه آزمایشی زنده

درباره استفاده از شبه عناصر اعتبارسنجی فرم user-* بیشتر بدانید.

آکاردئون اختصاصی

Browser Support

  • کروم: ۱۲۰.
  • لبه: ۱۲۰.
  • فایرفاکس: ۱۳۰.
  • سافاری: ۱۷.۲.

یک الگوی رابط کاربری رایج در وب، کامپوننت آکاردئونی است. برای پیاده‌سازی این الگو، شما چند عنصر <details> را با هم ترکیب می‌کنید، و اغلب آنها را از نظر بصری گروه‌بندی می‌کنید تا نشان دهید که به هم تعلق دارند.

قابلیت جدید کروم ۱۲۰، پشتیبانی از ویژگی name در عناصر <details> است. وقتی از این ویژگی استفاده می‌شود، چندین عنصر <details> که مقدار name یکسانی دارند، یک گروه معنایی تشکیل می‌دهند. حداکثر یک عنصر در گروه می‌تواند همزمان باز باشد: وقتی یکی از عناصر <details> را از گروه باز می‌کنید، عنصری که قبلاً باز بوده است به طور خودکار بسته می‌شود. این نوع آکاردئون، آکاردئون انحصاری نامیده می‌شود.

نسخه آزمایشی آکاردئون اختصاصی

عناصر <details> که بخشی از یک آکاردئون انحصاری هستند، لزوماً نباید خواهر و برادر باشند. آنها می‌توانند در سراسر سند پراکنده شوند.

CSS در چند سال گذشته و به خصوص در سال ۲۰۲۳، رنسانسی را تجربه کرده است. اگر در CSS تازه‌کار هستید یا فقط می‌خواهید اصول اولیه را مرور کنید، دوره رایگان Learn CSS ما را به همراه سایر دوره‌های رایگان ارائه شده در web.dev بررسی کنید.

تعطیلات خوبی را برایتان آرزو می‌کنیم و امیدواریم به زودی فرصتی برای استفاده از برخی از این ویژگی‌های جدید و درخشان CSS و UI در کارتان پیدا کنید!

⇾ تیم توسعه‌دهنده رابط کاربری کروم،