搜索...
一个 React Hook,用于查询浏览器功能的权限状态。
请查看 API。
点击下方链接跳转 GitHub 查看源代码。
const state = usePermission(permissionDesc, options) const { state, isSupported, query } = usePermission(permissionDesc, { controls: true, ...otherOptions })
type DescriptorNamePolyfill = | 'accelerometer' | 'accessibility-events' | 'ambient-light-sensor' | 'background-sync' | 'camera' | 'clipboard-read' | 'clipboard-write' | 'gyroscope' | 'magnetometer' | 'microphone' | 'notifications' | 'payment-handler' | 'persistent-storage' | 'push' | 'speaker' export type GeneralPermissionDescriptor = PermissionDescriptor | { name: DescriptorNamePolyfill } export type PermissionDesc = GeneralPermissionDescriptor | GeneralPermissionDescriptor['name'] | false
export type UsePermissionOptions<Controls extends boolean> = { /** * 暴露更多控制选项 * * @defaultValue false */ controls?: Controls /** * 是否立即查询 * * @defaultValue true */ immediate?: boolean /** * 状态变化时的回调函数 */ onStateChange?: (state: PermissionState) => void }
export type UsePermissionReturns<Controls extends boolean> = Controls extends true ? { /** * 若权限受支持 */ isSupported: boolean /** * 查询权限状态 */ state: RefObject<PermissionState | null> /** * 查询权限状态 */ query(): Promise<PermissionStatus | null> } : RefObject<PermissionState | null>