پوشاندن CSS، قوانین آرام برای تودرتوی CSS، ایجاد الگوهای آکاردئونی با عنصر <details>
، عمل enterpictureinpicture
برای Media Session API.
تغییرات توضیح داده شده در جدیدترین کانال بتا Chrome برای Android، ChromeOS، Linux، macOS و Windows اعمال میشود، مگر اینکه خلاف آن ذکر شده باشد. از طریق پیوندهای ارائه شده یا از فهرست موجود در chromestatus.com درباره ویژگی های فهرست شده در اینجا اطلاعات بیشتری کسب کنید. Chrome 120 از 1 نوامبر 2023 نسخه بتا است. میتوانید آخرین نسخه را در Google.com برای دسکتاپ یا در فروشگاه Google Play در Android بارگیری کنید.
CSS
این نسخه هفت ویژگی جدید CSS را اضافه می کند.
دستور CSS <image>
برای ویژگی های سفارشی ثبت شده
از دستور <image>
برای ویژگی های سفارشی ثبت شده با @property
یا registerProperty()
پشتیبانی می کند. دستور <image>
را می توان برای محدود کردن مقادیر ویژگی سفارشی به مقادیر url()
و تصاویر تولید شده مانند گرادیان استفاده کرد.
دستور CSS <transform-function>
و <transform-list>
برای خواص سفارشی ثبت شده
از دستورات <transform-function>
و <transform-list>
برای ویژگیهای سفارشی ثبتشده با @property
یا registerProperty()
پشتیبانی میکند.
از نحو میتوان برای محدود کردن مقادیر ویژگی سفارشی برای نمایش تبدیلها استفاده کرد. این همچنین امکان استفاده از انتقال ها و انیمیشن ها را مستقیماً در این ویژگی های سفارشی ثبت شده امکان پذیر می کند.
پرسش های رسانه ای: ویژگی اسکریپت نویسی
ویژگی رسانه اسکریپت برای بررسی اینکه آیا زبان های برنامه نویسی مانند جاوا اسکریپت در سند فعلی پشتیبانی می شوند یا خیر استفاده می شود. گزینههای معتبر «فعال»، «فقط اولیه» و «هیچکدام» هستند. با این حال، «فقط اولیه» هرگز با یک مرورگر مطابقت ندارد.
انتخابگر شبه کلاس :dir().
انتخابگر شبه کلاس :dir()
CSS عناصر را بر اساس جهتگیری، که بر اساس ویژگی HTML تعیین میشود، مطابقت میدهد.
:dir(ltr)
جهت متن از چپ به راست مطابقت دارد. :dir(rtl)
عناصر را با جهت متن از راست به چپ مطابقت می دهد.
این معادل با انتخابگرهای ویژگی [dir]
نیست زیرا با جهتهای به ارث رسیده از یک اجداد با ویژگی dir
مطابقت دارد، و به دلیل اینکه با جهت محاسبهشده از استفاده از dir=auto
(که جهتگیری را از نویسه اول متن با مشخص میکند) مطابقت دارد. جهت گیری قوی).
توابع نمایی CSS
توابع نمایی CSS را اضافه می کند: pow()
، sqrt()
، hypot()
، log()
و exp()
از مشخصات CSS Values و Units Level 4.
پوشش CSS
mask
CSS و ویژگیهای مرتبط مانند mask-image
و mask-mode
برای پنهان کردن یک عنصر (جزئی یا کامل) با پوشاندن یا برش تصویر در نقاط خاص استفاده میشوند.
این ویژگی ویژگی های -webkit-mask*
را حذف می کند و آنها را با مشخصات فعلی مطابقت می دهد. این شامل mask-image
، mask-mode
، mask-repeat
، mask-position
، mask-clip
، mask-origin
، mask-size
، و mask-composite
، و همچنین خلاصهنویسی mask
است. ارجاعات محلی mask-image
پشتیبانی می شوند، سریال سازی اکنون با مشخصات مطابقت دارد و مقادیر پذیرفته شده اکنون با مشخصات مطابقت دارند (به عنوان مثال، add
به جای source-over
برای mask-composite
.)
تودرتوی CSS آرام
این تغییر در پیادهسازی تودرتوی CSS به قوانین سبک تودرتو اجازه میدهد تا با یک عنصر شروع شوند، برای مثال h1
به جای نیاز به نماد &
در جلو، یا پیچیده شدن با is()
. مثال زیر اکنون در مشخصات معتبر است و در کروم 120 کار می کند.
.card {
h1 {
/* h1 does not start with a symbol */
}
}
HTML
الگوی آکاردئونی با استفاده از ویژگی نام در <details>
این ویژگی توانایی ساخت آکاردئون با استفاده از دنباله ای از عناصر HTML <details>
را اضافه می کند. یک ویژگی نام به عنصر <details>
اضافه می کند. هنگامی که از این ویژگی استفاده می شود، چندین عنصر <details>
که نام یکسانی دارند یک گروه را تشکیل می دهند. حداکثر یک عنصر در گروه می تواند به طور همزمان باز شود.
API های وب
اجازه انتقال ArrayBuffer به سازنده های VideoFrame، AudioData، EncodedVideoChunk، EncodedAudioChunk، ImageDecoder
این امکان جدا کردن بافرهای آرایه و استفاده از بافرهای مربوطه را در داخل VideoFrame، ImageDecoder، EncodedVideoChunk، EncodedAudioChunk، AudioData بدون کپی می دهد.
CSS Font Loading API FontFaceSet: روش check().
روش check()
FontFaceSet
بررسی میکند که آیا امکان نمایش متن با استفاده از فونتهای مشخص شده بدون تلاش برای استفاده از فونتهایی در FontFaceSet
وجود دارد که بارگذاری کامل نشدهاند. این به کاربران این امکان را میدهد تا با خیال راحت از فونت استفاده کنند بدون اینکه بعداً جایگزین فونت شوند.
بستن درخواست ها و CloseWatcher
درخواستهای بستن مفهوم جدیدی است که شامل درخواستهای کاربر برای بستن چیزی است که در حال حاضر باز است، با استفاده از کلید Esc روی دسکتاپ یا ژست یا دکمه برگشت در اندروید. ادغام آنها در کروم با دو تغییر همراه است:
-
CloseWatcher
، یک API جدید برای گوش دادن مستقیم و پاسخ به درخواست های بسته. - برای استفاده از چارچوب درخواست بسته جدید، به
<dialog>
وpopover=""
ارتقا دهید تا به دکمه بازگشت Android پاسخ دهند.
کارگران اختصاص داده شده و API دسترسی به فضای ذخیره سازی
کارگران اختصاص داده شده وضعیت دسترسی به فضای ذخیره سازی زمینه والد را به ارث خواهند برد. بنابراین، اگر یک سند از طریق document.requestStorageAccess()
دسترسی به فضای ذخیرهسازی را به دست آورد و سپس یک Worker اختصاصی ایجاد کند، کارگر نیز به ذخیرهسازی دسترسی خواهد داشت (و میتواند به کوکیهای پارتیشن نشده دسترسی داشته باشد.)
FedCM: خطای API و AutoSelectedFlag API
API های اختصاصی برای کمک به توسعه دهندگان و کاربران برای درک بهتر جریان احراز هویت. هر دو API پس از ارسال مجوز کاربر برای ورود به یک وب سایت یا برنامه (در این زمینه به عنوان یک طرف متکی (RP) شناخته می شود) با ارائه دهنده هویت فعال می شوند. به عبارت دیگر پس از کلیک کاربر بر روی دکمه Continue as .
با Error API، اگر تلاش کاربر برای ورود به سیستم ناموفق باشد، ارائهدهنده هویت میتواند دلایل را با مرورگر به اشتراک بگذارد تا هم کاربران و هم توسعهدهندگان RP را بهروز نگه دارد.
با AutoSelectedFlag API، هم ارائهدهنده هویت و هم توسعهدهندگان RP میتوانند درک بهتری درباره UX ورود به سیستم داشته باشند و بر این اساس عملکرد و معیارهای بخش را ارزیابی کنند.
در پست وبلاگ FedCM Chrome 120 بیشتر بیاموزید.
به روز رسانی عملکرد فریم های حصاردار
یک گزینه قالب اضافی برای ماکروهای اندازه تبلیغ مخاطب محافظت شده در API مخاطب محافظت شده در جعبه ایمنی حریم خصوصی وجود دارد. یک ویژگی Opt-in به شما امکان می دهد از ماکروها برای تعیین اندازه تبلیغی که برنده حراج می شود در URL آگهی استفاده کنید، به عنوان مثال:
https://ad.com?width={/%AD_WIDTH%}&height={/%AD_HEIGHT%}
برای سازگاری بیشتر با انواع دیگر ماکروها در مخاطب محافظت شده، مانند ماکروهایی که توسط deprecatedReplaceInURN
و registerAdMacro()
استفاده میشوند، در Chrome 120، ما توانایی استفاده از ${AD_WIDTH} و ${AD_HEIGHT} را بهعنوان قالب ماکروها اضافه میکنیم. علاوه بر فرمت فعلی
چراغ های خودکار اکنون به همه URL های ثبت شده ارسال می شوند. قبلاً، تنها مقصدهایی که هنگام فراخوانی setReportEventDataForAutomaticBeacons()
مشخص شده بودند، چراغهای خودکار دریافت میکردند، حتی اگر آن مقصد به نام registerAdBeacon()
برای reserved.top_navigation
در کار خود. اکنون، هر مقصدی که registerAdBeacon()
برای reserved.top_navigation
فراخوانی میکند، یک فانوس دریایی خودکار دریافت میکند، اما تنها مقصدهایی که در setReportEventDataForAutomaticBeacons()
مشخص شدهاند، دادههای خودکار خودکار را همراه با بیکن دریافت میکنند. پارامتر once
در setReportEventDataForAutomaticBeacons()
اکنون تعیین می کند که آیا داده ها یک بار ارسال می شوند یا خیر، به جای اینکه تعیین کند که آیا کل بیکن یک بار ارسال شده است یا خیر.
حاشیه پیمایش ناظر تقاطع
Intersection Observer scrollMargin
به توسعه دهندگان اجازه می دهد تا اهدافی را در داخل ظروف اسکرول تو در تو مشاهده کنند که در حال حاضر توسط کانتینرهای اسکرول بریده شده اند. این امر با بزرگ کردن راسته برش ظرف توسط scrollMargin
هنگام محاسبه تقاطع به دست می آید.
گزارش نقض خط مشی مجوزها
این API خطمشی مجوزها را با API گزارش ادغام میکند و به توسعهدهندگان وب اجازه میدهد تا نقاط پایانی را پیکربندی کنند که گزارشهای نقض خطمشی مجوزها به آنها ارسال میشود، و به مالکان سایت اجازه میدهد ببینند چه زمانی ویژگیهای غیرمجاز در صفحاتشان در فیلد درخواست میشود.
همچنین شامل هدر Permissions-Policy-Report-Only
که امکان ارسال گزارش ها بر اساس یک خط مشی پیشنهادی (مشابه Content-Security-Policy-Report-Only
) را فراهم می کند تا تغییرات خط مشی را بتوان از نظر شکستگی احتمالی قبل از اجرای آنها ارزیابی کرد. در حالت عادی و اجباری
Media Session API: enterpictureinpicture
action
یک اکشن enterpictureinpicture
را به Media Session API اضافه می کند. وبسایتها میتوانند یک کنترلکننده عمل ثبت کنند که میتواند برای باز کردن پنجره تصویر در تصویر یا سند تصویر در تصویر استفاده شود.
در تصویر در تصویر خودکار برای برنامه های وب بیشتر بیاموزید.
پشتیبانی از WebGPU f16
امکان استفاده از نیمه دقیق نوع ممیز شناور f16 در سایه زن های WebGPU (WGSL).
توسعه دهندگان می توانند از ویژگی 'shader-f16' از مشخصات WebGPU و پسوند 'f16' از مشخصات WGSL برای دسترسی به متغیرهای ممیز شناور 16 بیتی و APIها در سایه زن خود استفاده کنند.
قابلیت های Media: پشتیبانی از HDR را با decodingInfo()
پرس و جو کنید
API قابلیتهای رسانه را گسترش میدهد تا امکان تشخیص پشتیبانی از رندر HDR را از طریق سه فیلد فرهنگ لغت پیکربندی ویدیوی جدید: hdrMetadataType
، colorGamut
، و transferFunction
. کروم الگوریتمهای نگاشت آهنگ خود را پیادهسازی میکند، بنابراین همیشه برای ابردادههای ثابت HDR10 (smpteSt2086) true خواهد بود. ابردادههای دینامیک HDR10+ (smpteSt2094-10) و Dolby Vision (smpteSt2094-40) در حال حاضر پشتیبانی نمیشوند، بنابراین false برمیگردند. ما پیشبینی میکنیم در آینده پشتیبانی از ابرداده پویا اضافه شود، بنابراین این API به توسعهدهندگان اجازه میدهد محتوای مناسب را برای کاربران دارای پشتیبانی انتخاب کنند.
آمار MediaStreamTrack (ویدئو)
یک API که شمارندههای فریم (تحویلشده، دور انداختهشده، کل) را برای ویدیوهای نوع MediaStreamTracks نشان میدهد. آمارهای صوتی با راه اندازی ویژگی جداگانه Chrome پوشش داده می شود.
Private Aggregation API: انتخاب هماهنگ کننده تجمع
تغییر در Private Aggregation API برای ارائه مکانیزمی برای انتخاب هماهنگ کننده برای رمزگذاری بار (از فهرست مجاز مشخص شده توسط فروشنده). انتخاب سرویس با یک گزینه اضافی در فراخوانی های SharedStorage run()
و selectURL()
و در تماس های runAdAuction()
و joinAdInterestGroup()
Protected Audience انجام می شود. رویکرد گسترده تا حد زیادی با رویکرد Attribution Reporting API هماهنگ است.
Login Status API در FedCM
Login Status API (که قبلاً IdP Sign-in Status API نامیده می شد) به ارائه دهندگان هویت اجازه می دهد زمانی که کاربران خود وارد یا خارج می شوند به مرورگر سیگنال دهند.
این مورد توسط FedCM برای رسیدگی به یک حمله زمانبندی بیصدا استفاده میشود، و با انجام این کار، به FedCM اجازه میدهد بدون کوکیهای شخص ثالث به طور کامل کار کند.
در آینده این API ممکن است برای موارد استفاده بیشتر در دسترس باشد.
در پست وبلاگ اطلاعیه بیشتر بدانید.
مشاهده انتقال ها: غیر قابل تهی کردن تماس برگشتی
تماس startViewTransition
در حال حاضر یک نوع پاسخ به تماس اختیاری با مقدار پیشفرض null دریافت میکند: startViewTransition(optional UpdateCallback? callback = null)
.
این ویژگی این را به یک نوع غیر قابل تهی تغییر می دهد: startViewTransition(optional UpdateCallback callback)
.
محصور کردن کلید X25519Kyber768 برای TLS
با استقرار الگوریتم توافقنامه کلید مقاوم در برابر کوانتومی Kyber768، از ترافیک فعلی Chrome TLS در برابر تحلیل رمزنگاری کوانتومی آینده محافظت کنید. این یک توافق کلید هیبریدی X25519 + Kyber768 بر اساس استاندارد IETF است. این مشخصات و راه اندازی خارج از محدوده W3C است. این قرارداد کلیدی به عنوان رمز TLS راه اندازی می شود و باید برای کاربران شفاف باشد.
آزمایش های مبدا در حال انجام است
در Chrome 120 میتوانید آزمایشهای اصلی جدید زیر را انتخاب کنید.
سرصفحه درخواست HTTP "اولویت".
این ویژگی هدر درخواست priority
برای تمام درخواست های HTTP با اطلاعات اولویت درخواست در زمان ارسال اضافه می کند.
RFC 9218 (طرح اولویتبندی توسعهیافته برای HTTP) یک هدر درخواست HTTP «اولویتدار» را برای ارسال سیگنال اولویت درخواست به مبدا (و واسطهها) تعریف میکند. همچنین فرآیندهای مذاکره و فریم های سطح پروتکل را برای HTTP/2 و HTTP/3 برای حمل اطلاعات اولویت یکسان تعریف می کند. هدر فقط می تواند اولویت اولیه یک منبع را زمانی که برای اولین بار درخواست شده است نشان دهد، در حالی که مکانیسم های مبتنی بر فریم امکان تغییر اولویت را پس از واقعیت فراهم می کند. هدر میتواند سرتاسر سرورهای مبدأ را کار کند (و مکانیزمی را برای مبدا فراهم کند تا اولویت را در صورت شناسایی توسط واسطهها لغو کند) در حالی که فریمها محدود به عملکرد در سطح پیوند هستند. این ویژگی به طور خاص برای پشتیبانی از طرح اولویت بندی مبتنی بر هدر است.
گسترش API دسترسی به فضای ذخیره سازی (SAA) به فضای ذخیره سازی غیر کوکی
ما یک برنامه افزودنی از Storage Access API (سازگار با عقب) را پیشنهاد میکنیم تا امکان دسترسی به فضای ذخیرهسازی پارتیشن نشده (کوکی و غیرکوکی) در زمینه شخص ثالث را فراهم کند.
مجوز دسترسی به شبکه خصوصی برای آرام کردن محتوای ترکیبی
به منظور برقراری اتصال به دستگاههایی در یک شبکه محلی که نامهای منحصربهفرد جهانی ندارند و بنابراین نمیتوانند گواهیهای TLS را دریافت کنند، این ویژگی گزینه جدیدی برای fetch()
برای اعلام قصد توسعهدهندگان برای صحبت با چنین دستگاهی معرفی میکند. ویژگی جدید کنترل شده توسط سیاست برای دسترسی هر سایت به این قابلیت و هدرهای جدید برای پاسخ پیش از پرواز سرور برای ارائه ابرداده های اضافی.
برای آزمایش اولیه مجوز دسترسی به شبکه خصوصی ثبت نام کنید .
دسترسی نامحدود به performance.measureUserAgentSpecificMemory()
() performance.measureUserAgentSpecificMemory مشخص شده است که فقط در محیط های جدا شده با منبع متقاطع (در پشت COOP/COEP) در دسترس باشد. این ویژگی محدودیت COOP/COEP را حذف میکند تا آزمایشهای رگرسیون و اندازهگیری تأثیر را در زمانی که قادر به استقرار کامل COOP/COEP نیستید، مجاز میسازد. توجه داشته باشید که performance.memory (API قدیمی) نمی تواند برای این منظور استفاده شود زیرا هرگز در کارگران فعال نشده است.
performance.measureUserAgentSpecificMemory()
این ویژگی یک تابع performance.measureUserAgentSpecificMemory()
اضافه می کند که میزان استفاده از حافظه صفحه وب را تخمین می زند. برای استفاده از API، وبسایت باید از مبدأ متقابل جدا باشد.
محرومیت ها و حذف ها
این نسخه از Chrome موارد منسوخ و حذف فهرست شده در زیر را معرفی می کند. برای مشاهده لیستی از لغو برنامه ریزی شده، منسوخ شدن فعلی و حذف قبلی، از ChromeStatus.com دیدن کنید.
این نسخه از Chrome یک ویژگی را منسوخ میکند.
پشتیبانی Theora را منسوخ و حذف کنید
Chrome به دلیل خطرات امنیتی در حال ظهور، پشتیبانی از کدک ویدیویی Theora را در کروم دسکتاپ منسوخ و حذف خواهد کرد. استفاده کم (و اکنون اغلب نادرست) Theora دیگر پشتیبانی برای اکثر کاربران را توجیه نمی کند.
این نسخه کروم دو ویژگی را حذف می کند.
حذف داده ها: URL در SVGUseElement
اختصاص دادن یک داده: URL در SVGUseElement می تواند باعث XSS شود. و این نیز منجر به دور زدن Trusted Types شد. بنابراین، ما در نظر داریم که پشتیبانی از آن را منسوخ و حذف کنیم.
اجباری همان مبدأ را در CSPEE حذف کنید
یک درمان ویژه برای iframe های یکسان را از CSP Embedded Enforcement حذف می کند. این رفتار اجرای CSP Embedded Enforcement را برای iframe های متقاطع و iframe های با مبدا همسو می کند.