JavaScript 全屏方案(分享)

基本实现

基本情况是属于只是鼠标点击全屏按钮

  • document.exitFullscreen(),退出全屏
  • Document.requestFullscreen(),开启全屏
  • document.fullscreenElement,返回当前全屏元素
<template>
  <div>
    <el-button v-show="!hasFullScreen" @click="fullScreen"> 开启全屏 </el-button>
    <el-button v-show="hasFullScreen" @click="fullScreen"> 退出全屏 </el-button>
  </div>
</template>
<script>
  export default {
    data() {
      return {
        // 全屏状态
        hasFullScreen: false,
      };
    },
    methods: {
      fullScreen() {
        // 已开启全屏,需要退出
        if (this.hasFullScreen && document.fullscreenElement) {
          document.exitFullscreen();
          this.hasFullScreen = false;
          // 未开启全屏,需要开启
        } else {
          document.documentElement.requestFullscreen();
          this.hasFullScreen = true;
        }
      },
    },
  };
</script>

特殊情况

存在按键盘F11、手动点全屏后中间的×,先说说几种方案

  1. fullscreenchange,这个只能监听手动点击按钮的情况,监听不到F11、手动点×,这个方案就不行
  2. 阻止键盘F11默认事件,然后手动调用 this.fullScreen(),这种方案其实也不行,正常情况下F11是可以监听到的,但是如果用户鼠标点击搜索栏时F11监听不到,通过F11开启全屏后,再次点击F11也监听不到,这个时候vue中的全屏状态就管理不了了(这里要说明一点,F11不属于全屏,只是隐藏了导航栏等,fullscreenchange 监听不到,document.fullscreenElement 也没有值,所以F11原生的事件直接用不了)
  3. 最好的是通过innerHeightouterHeight,来判断是否全屏
<template>
  <div>
    <el-button v-show="!hasFullScreen" @click="fullScreen"> 开启全屏 </el-button>
    <el-button v-show="hasFullScreen" @click="fullScreen"> 关闭全屏 </el-button>
  </div>
</template>
<script>
  export default {
    data() {
      return {
        // 全屏状态
        hasFullScreen: false,
      };
    },
    mounted() {
      // 监听浏览器窗口来判断是否全屏,用来管理全屏状态
      window.addEventListener("resize", (e) => {
        // 这里我准备判断是否相等,但是不知道为什么会存在偏差
        // 我的电脑是16的偏差,我用我同事的电脑测试,有的是14 有的是18
        if (Math.abs(innerHeight - outerHeight) < 30) {
          this.hasFullScreen = true;
        } else {
          // 不需要重复修改,这里也有可能是用户修改窗口尺寸
          if(!this.hasFullScreen) return
          this.hasFullScreen = false;
        }
      });
    },
    methods: {
      fullScreen() {
        if (this.hasFullScreen && document.fullscreenElement) {
          document.exitFullscreen();
        } else {
          document.documentElement.requestFullscreen();
        }
      },
    },
  };
</script>
  • 13
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值