useScreenSafeArea
响应式 env(safe-area-inset-*)
演示
顶部
右侧
底部
左侧
用法
为了使页面能够在屏幕上完全渲染,首先必须在 viewport
元标签中设置额外的属性 viewport-fit=cover
,viewport
元标签可能如下所示
html
<meta name="viewport" content="initial-scale=1, viewport-fit=cover" />
然后我们可以在组件中使用 useScreenSafeArea
,如下所示
ts
import { useScreenSafeArea } from '@vueuse/core'
const {
top,
right,
bottom,
left,
} = useScreenSafeArea()
更多详细信息,您可以参考此文档:为 iPhone X 设计网站
组件用法
此函数还通过
@vueuse/components
包提供了一个无渲染组件版本。 了解有关用法的更多信息。
vue
<template>
<UseScreenSafeArea top right bottom left>
content
</UseScreenSafeArea>
</template>
类型声明
typescript
/**
* Reactive `env(safe-area-inset-*)`
*
* @see https://vueuse.org.cn/useScreenSafeArea
*/
export declare function useScreenSafeArea(): {
top: Ref<string, string>
right: Ref<string, string>
bottom: Ref<string, string>
left: Ref<string, string>
update: () => void
}
源代码
贡献者
Anthony Fu
Anthony Fu
vaakian X
Ayaka Rizumu
Jelf