Vue3 使用 v-scale-screen 如何使用js点击事件触发全屏
大家肯定遇到过需要点击大屏内元素后,自动进入全屏模式。
一般大家的方案会是使用js获取界面元素 然后设置设置其全屏方法
typescript
const isFullscreen = document.fullscreenElement !== null;
const elem = document.getElementById("layout");
if (isFullscreen) {
// 此处需判断不同浏览器的全屏api
if (document.exitFullscreen) {
await document.exitFullscreen();
}
} else {
if (elem?.requestFullscreen) {
await elem.requestFullscreen();
}
}
此方案与v-scale-screen有冲突,不管是给VScaleScreen组件设置id还是给其子组件或父组件设置id 都会出现界面拉伸错误或者直接黑屏的问题
vue
<template>
<VScaleScreen width="1920" height="1080" :delay="200">
<div class="layout">
...
</div>
</VScaleScreen>
</template>
<script lang="ts" setup>
import VScaleScreen from "v-scale-screen"
</script>
解决方案是 screenfull
bash
npm install screenfull
typescript
import screenfull from 'screenfull'
// 全屏
const fullscreen = async () => {
if (screenfull.isEnabled) {
if (!screenfull.isFullscreen) {
// 全屏
screenfull.request()
} else {
// 取消全屏
screenfull.exit()
}
}
}