صفت بی اثر

ویژگی inert یک ویژگی جهانی HTML است که نحوه حذف و بازیابی رویدادهای ورودی کاربر را برای یک عنصر ساده می‌کند، از جمله رویدادهای تمرکز و رویدادهای فناوری‌های کمکی.

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

  • کروم: 102.
  • لبه: 102.
  • فایرفاکس: 112.
  • سافاری: 15.5.

منبع

Inert یک رفتار پیش‌فرض در عناصر محاوره‌ای است، مانند زمانی که از showModal برای باز کردن گفتگو برای کاربران برای انتخاب انتخاب و سپس حذف آن از صفحه استفاده می‌کنید. پس از باز کردن یک <dialog> بقیه صفحه بی اثر می شود، برای مثال دیگر نمی توانید روی پیوندها کلیک کنید یا برگه بزنید.

می توانید از ویژگی inert برای دستیابی به رفتار مشابه در سایر عناصر استفاده کنید.

Inert به معنای عدم توانایی حرکت است، بنابراین وقتی چیزی بی اثر را علامت گذاری می کنید، حرکت یا تعامل را از آن عناصر DOM حذف می کنید.

<div>
  <label for="button1">Button 1</label>
  <button id="button1">I am not inert</button>
</div>
<div inert>
  <label for="button2">Button 2</label>
  <button id="button2">I am inert</button>
</div>

در اینجا، inert در دومین عنصر <div> حاوی button2 اعلام شده است، بنابراین تمام محتوای موجود در این <div> ، از جمله دکمه و برچسب، نمی توانند فوکوس دریافت کنند یا روی آنها کلیک شود.

ویژگی inert به ویژه برای دسترسی مفید است، به ویژه برای جلوگیری از به دام افتادن فوکوس.

دسترسی بهتر

دستورالعمل‌های دسترسی به محتوای وب نیاز به مدیریت تمرکز و ترتیب تمرکز معقول و قابل استفاده دارد. این شامل قابلیت کشف و تعامل است. پیش از این، قابلیت کشف را می‌توان با aria-hidden="true" سرکوب کرد، اما تعامل دشوارتر است.

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

دو مورد عمده برای اعمال inert به یک عنصر برای امکان دسترسی بهتر وجود دارد:

  • هنگامی که یک عنصر بخشی از درخت DOM است، اما خارج از صفحه یا پنهان است.
  • زمانی که یک عنصر بخشی از درخت DOM است، اما باید غیر تعاملی باشد.
عناصر DOM خارج از صفحه یا پنهان

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

عناصر DOM غیر تعاملی

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

برای ارائه بهترین تجربه برای کاربران، وضعیت رابط کاربری را مشخص کنید و تمرکز را در قسمتی از صفحه که تعاملی است، «به دام بیاندازید».

به دام انداختن تمرکز

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

با استفاده از inert ، می توانید اطمینان حاصل کنید که تنها محتوای قابل کشف قابل دسترسی است. این برای:

  • مسدود کردن عناصر مانند گفتگوی مودال، منوی تله گذاری فوکوس، یا ناوبری جانبی.
  • چرخ و فلک با اقلام غیر فعال.
  • محتوای فرم غیرقابل اجرا (به عنوان مثال، محو و غیرفعال کردن فیلدهای "آدرس حمل و نقل" هنگامی که کادر انتخاب "همان آدرس صورتحساب" علامت زده شده است).
  • غیرفعال کردن کل رابط کاربری در حالت ناسازگار.
عناصر inert را بصری نشان دهید

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

[inert], [inert] * {
  opacity: 0.5;
  pointer-events: none;
  cursor: default;
  user-select: none;
}

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

چه فعل و انفعالات و حرکتی مسدود شده است؟

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

مقدار پیش فرض inert false است.