تجربه ای همهجانبه و تمام صفحه را برای موارد مختلف از جمله وب سایت های تعاملی، بازی ها و پخش جریانی از راه دور دسکتاپ یا برنامه ارائه دهید.
از آنجایی که کاربران بیشتر و بیشتری بیشتر وقت خود را در مرورگر می گذرانند، وب سایت های تعاملی غنی، بازی ها، پخش جریانی از راه دور دسکتاپ و پخش برنامه ها تلاش می کنند تا تجربه ای همه جانبه و تمام صفحه را ارائه دهند. برای انجام این کار، سایت ها در حالی که در حالت تمام صفحه هستند به کلیدهای ویژه و میانبرهای صفحه کلید نیاز دارند تا بتوان از آنها برای ناوبری، منوها یا بازی استفاده کرد. چند نمونه از کلیدهایی که ممکن است مورد نیاز باشد عبارتند از Esc , Alt + Tab , Cmd + ` و Ctrl + N .
بهطور پیشفرض، این کلیدها برای برنامه وب در دسترس نیستند، زیرا توسط مرورگر یا سیستم عامل زیرین ضبط میشوند. API قفل صفحهکلید به وبسایتها امکان میدهد از تمام کلیدهای موجود مجاز توسط سیستم عامل میزبان استفاده کنند (به سازگاری مرورگر مراجعه کنید).
با استفاده از Keyboard Lock API
رابط Keyboard
صفحه کلید API عملکردهایی را ارائه می دهد که ضبط فشار کلید از صفحه کلید فیزیکی و همچنین دریافت اطلاعات در مورد چیدمان صفحه کلید کاربر را تغییر می دهد.
پیش نیاز
دو نوع تمام صفحه در مرورگرهای مدرن موجود است: راه اندازی شده با جاوا اسکریپت از طریق API تمام صفحه و راه اندازی شده توسط کاربر از طریق میانبر صفحه کلید. API قفل صفحه کلید تنها زمانی در دسترس است که تمام صفحه آغاز شده با جاوا اسکریپت فعال باشد. در اینجا یک نمونه از تمام صفحه آغاز شده با جاوا اسکریپت آورده شده است:
await document.documentElement.requestFullscreen();
تشخیص ویژگی
برای بررسی اینکه آیا API قفل صفحه کلید پشتیبانی می شود، می توانید از الگوی زیر استفاده کنید:
if ('keyboard' in navigator && 'lock' in navigator.keyboard) {
// Supported!
}
قفل کردن صفحه کلید
متد lock()
رابط Keyboard
پس از فعال کردن ضبط فشار کلید برای هر یک یا همه کلیدهای صفحه کلید فیزیکی، یک وعده را برمیگرداند. این روش فقط میتواند کلیدهایی را که سیستم عامل اصلی به آنها دسترسی دارد، ضبط کند. متد lock()
آرایه ای از یک یا چند کد کلید را برای قفل می گیرد. اگر هیچ کد کلیدی ارائه نشود، همه کلیدها قفل خواهند شد. فهرستی از مقادیر کد کلید معتبر در تنظیمات UI Events KeyboardEvent Code Values موجود است.
گرفتن همه کلیدها
مثال زیر تمام فشارهای کلید را نشان می دهد.
navigator.keyboard.lock();
گرفتن کلیدهای خاص
مثال زیر کلیدهای W ، A ، S و D را نشان می دهد. بدون توجه به اینکه کدام اصلاح کننده با فشار دادن کلید استفاده می شود، این کلیدها را می گیرد. با فرض طرحبندی QWERTY ایالات متحده، ثبت "KeyW"
تضمین میکند که W ، Shift + W ، Control + W ، Control + Shift + W ، و سایر ترکیبهای اصلاحکننده کلید با W به برنامه ارسال میشوند. همین امر در مورد "KeyA"
، "KeyS"
و "KeyD"
صدق می کند.
await navigator.keyboard.lock([
"KeyW",
"KeyA",
"KeyS",
"KeyD",
]);
با استفاده از رویدادهای صفحه کلید می توانید به فشارهای کلید گرفته شده پاسخ دهید. برای مثال این کد از رویداد onkeydown
استفاده می کند:
document.addEventListener('keydown', (event) => {
if ((event.code === 'KeyA') && !(event.ctrlKey || event.metaKey)) {
// Do something when the 'A' key was pressed, but only
// when not in combination with the command or control key.
}
});
باز کردن قفل صفحه کلید
unlock()
unlock تمام کلیدهای گرفته شده توسط متد lock()
را باز می کند و به صورت همزمان برمی گرداند.
navigator.keyboard.unlock();
وقتی یک سند بسته می شود، مرورگر همیشه به طور ضمنی unlock()
فراخوانی می کند.
نسخه ی نمایشی
میتوانید با اجرای دمو در Glitch، API قفل صفحه کلید را آزمایش کنید. حتماً کد منبع را بررسی کنید . با کلیک بر روی دکمه Enter تمام صفحه در زیر، دمو در یک پنجره جدید راه اندازی می شود تا بتواند وارد حالت تمام صفحه شود.
ملاحظات امنیتی
یکی از نگرانیهای این API این است که میتوان از آن برای گرفتن همه کلیدها استفاده کرد و (در ارتباط با API تمام صفحه و PointerLock API ) از خروج کاربر از صفحه وب جلوگیری کرد. برای جلوگیری از این امر، این مشخصات از مرورگر میخواهد که راهی برای خروج کاربر از قفل صفحه کلید فراهم کند، حتی اگر همه کلیدها توسط API درخواست شده باشند. در کروم، این دریچه فرار یک فشار طولانی (دو ثانیه ای) کلید Esc برای خروج از قفل صفحه کلید است.
لینک های مفید
- پیش نویس مشخصات
- مخزن GitHub
- ورودی ChromeStatus
- اشکال ردیابی کروم
- کدهای کلید برای صفحه کلیدهای استاندارد
قدردانی
این مقاله توسط Joe Medley و Kayce Basques بررسی شده است. مشخصات قفل صفحه کلید توسط گری کامارکیک و جیمی والچ نوشته شده است. تصویر قهرمان توسط کن سوارز در Unsplash .