Baseline Widely available
Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
Note: This feature is available in Web Workers.
The query()
method of the LockManager
interface returns a Promise
that resolves with an object containing information about held and pending locks.
None.
Return valueA Promise
that resolves with an object containing a snapshot of the LockManager
state. The object has the following properties:
held
An array of LockInfo
objects for held locks.
pending
An array of LockInfo
objects for pending lock requests.
The LockInfo
object can have the following properties:
name
The name passed to LockManager.request()
when the lock was requested.
mode
The access mode passed to LockManager.request()
when the lock was requested. The mode is either "exclusive"
or "shared"
.
clientId
The unique identity of the context where LockManager.request()
is called. This is the same value as Client.id
.
This method may return a promise rejected with a DOMException
of one of the following types:
InvalidStateError
DOMException
Thrown if the environments document is not fully active.
SecurityError
DOMException
Thrown if a lock manager cannot be obtained for the current environment.
const state = await navigator.locks.query();
for (const lock of state.held) {
console.log(`held lock: name ${lock.name}, mode ${lock.mode}`);
}
for (const request of state.pending) {
console.log(`requested lock: name ${request.name}, mode ${request.mode}`);
}
Specifications Browser compatibility
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4