Skip to content

useFullscreen

类别
导出体积
1.1 kB
上次更改
3 days ago

响应式的全屏 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/2025
dd316 - feat: use passive event handlers everywhere is possible (#4477)
v12.0.0-beta.1 on 11/21/2024
0a9ed - feat!: drop Vue 2 support, optimize bundles and clean up (#4349)
v10.2.1 on 6/28/2023
14edb - fix: skip exiting when not in fullscreen mode (#3144)
v10.1.0 on 4/22/2023
4a7a1 - fix: isFullscreen handling for mutliple fullscreen elements (#3000)
v10.0.0-beta.3 on 4/12/2023
2e467 - fix!: better cross-platform compatibility (#2915)
v10.0.0-beta.0 on 3/14/2023
9d394 - fix: handle Safari iOS (#2822)
v9.11.0 on 1/17/2023
d5321 - fix(components): mark defineComponent as pure (#2623)