useFullscreen
响应式的全屏 API。它添加了方法,用于将特定元素 (及其后代) 呈现为全屏模式,并在不再需要时退出全屏模式。这使得可以使用用户的整个屏幕来呈现所需的内容,例如在线游戏,在全屏模式下移除所有浏览器用户界面元素和其他应用程序,直到关闭全屏模式为止。
示例
使用方法
js
import { useFullscreen } from '@vueuse/core'
const { isFullscreen, enter, exit, toggle } = useFullscreen()
指定元素全屏显示。某些平台 (例如 iOS 的 Safari) 仅允许在视频元素上全屏显示。
ts
const el = ref(null)
const { isFullscreen, enter, exit, toggle } = useFullscreen(el)
html
<video ref="el"></video>
组件使用
html
<div>
<UseFullscreen v-slot="{ toggle }">
<video />
<button @click="toggle">进入全屏模式</button>
</UseFullscreen>
</div>
类型声明
typescript
export interface UseFullscreenOptions extends ConfigurableDocument {
/**
* 卸载组件时自动退出全屏
*
* @default false
*/
autoExit?: boolean
}
/**
* 响应式 Fullscreen API.
*
* @see https://vueuse.org/useFullscreen
* @param target
* @param options
*/
export declare function useFullscreen(
target?: MaybeElementRef,
options?: UseFullscreenOptions,
): {
isSupported: ComputedRef<boolean>
isFullscreen: Ref<boolean, boolean>
enter: () => Promise<void>
exit: () => Promise<void>
toggle: () => Promise<void>
}
export type UseFullscreenReturn = ReturnType<typeof useFullscreen>
源码
贡献者
Anthony Fu
一纸忘忧
Fernando Fernández
wheat
Antério Vieira
Anthony Fu
tawen
zaqvil
Yvan Zhu
vaakian X
Jelf
webfansplz
Shinigami
Alex Kozack
更新日志
v12.4.0
on 1/10/2025v12.0.0-beta.1
on 11/21/2024v10.2.1
on 6/28/2023v10.1.0
on 4/22/2023v10.0.0-beta.3
on 4/12/2023v10.0.0-beta.0
on 3/14/2023v9.11.0
on 1/17/2023