WakeLock:request() 方法
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
io error: No such file or directory (os error 2) (/home/runner/work/yari/yari/mdn/translated-content/files/zh-cn/web/api/screen_wake_lock_api/index.md)
WakeLock
接口的 request()
方法用于请求系统屏幕唤醒锁。如果请求成功,该方法会返回一个兑现为 WakeLockSentinel
对象的 Promise
。
屏幕唤醒锁可阻止设备屏幕在应用程序中需要保持运行时变暗或锁定。
语法
js
request(type)
参数
返回值
一个 Promise
对象,它将解析为一个 WakeLockSentinel
对象。
异常
NotAllowedError
DOMException
-
当无法获取屏幕唤醒锁时抛出异常,可能有以下原因:
示例
以下异步函数请求一个 WakeLockSentinel
对象。request()
方法被包裹在一个 try...catch
语句中,以处理浏览器因任何原因拒绝请求的情况。
js
const requestWakeLock = async () => {
try {
const wakeLock = await navigator.wakeLock.request("screen");
} catch (err) {
// 唤醒锁请求失败——通常是系统原因,例如设备电量不足
console.log(`${err.name}, ${err.message}`);
}
};
requestWakeLock();
设备可能会在授予屏幕唤醒锁后撤销它,返回的 WakeLockSentinel
对象可用于检查屏幕唤醒锁的状态,以及手动取消持有的屏幕唤醒锁。
规范
Specification |
---|
Screen Wake Lock API # the-request-method |
浏览器兼容性
BCD tables only load in the browser