vue实现f11全屏esc退出全屏

<template>
  <div>
    <p>页面内容</p>
    <el-button type="primary" @click="enter_full_screen" v-if="!full"
      >进入</el-button
    >
    <el-button type="primary" @click="exitFullscreen" v-else
      >退出</el-button
    >
  </div>
</template>

<script>
export default {
  data() {
    return {
      //true是进入全屏,false是退出全屏
      full: false,
    };
  },
  created() {
    //指向问题先保存
    let that = this;
    //这里是监听ESC的
    window.onresize = function () {
      if (!that.checkFull()) {
        // 退出全屏后要执行的动作
        console.log("退出全屏");
        that.full = false;
      }
    };
  },
  mounted() {
    //这里是监听F11案件的
    window.addEventListener("keydown", this.KeyDown, true); // 监听按键事件
  },
  methods: {
    //进入全屏模式
    enter_full_screen() {
      this.full = true;
      document.documentElement.webkitRequestFullScreen();
    },
    //退出全屏模式
    exitFullscreen() {
      this.full = false;
      if (document.exitFullscreen) {
        document.exitFullscreen();
      } else if (document.msExitFullscreen) {
        document.msExitFullscreen();
      } else if (document.mozCancelFullScreen) {
        document.mozCancelFullScreen();
      } else if (document.webkitExitFullscreen) {
        document.webkitExitFullscreen();
      }
    },
    //监听解决F11打开后无法esc退出同时退出全屏的按钮也失效问题。
    KeyDown(event) {
      if (event.keyCode === 122) {
        event.returnValue = false;
        this.enter_full_screen(); //这里方的是触发全屏的方法
      }
    },
    //监听ESC事件,解决点击按钮全屏后按ESC退出再点击按钮不生效问题。
    checkFull() {
      //判断浏览器是否处于全屏状态 (需要考虑兼容问题)
      //火狐浏览器
      var isFull =
        document.mozFullScreen ||
        document.fullScreen ||
        //谷歌浏览器及Webkit内核浏览器
        document.webkitIsFullScreen ||
        document.webkitRequestFullScreen ||
        document.mozRequestFullScreen ||
        document.msFullscreenEnabled;
      if (isFull === undefined) {
        isFull = false;
      }
      return isFull;
    },
  },
};
</script>

<style>
</style>



  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值