关于解决监听F11全屏的监听思路

弄了好久的screenfull插件啊 keydown啊之类的监听 各种bug层出不穷 F11只能监听到第一次 改变retunvalue为false 再添加别的方法控制变量啊什么的 就不行了 就如下图这种哈 完全没有用

这里不是解决登录自动全屏哈
登录全屏可以使用这个方法

    // 全屏
    handleFullScreen () {
      let element = document.documentElement;
      if (element.requestFullscreen) {
        element.requestFullscreen();
      } else if (element.webkitRequestFullScreen) {
        element.webkitRequestFullScreen();
      } else if (element.mozRequestFullScreen) {
        element.mozRequestFullScreen();
      } else if (element.msRequestFullscreen) {
        // IE11
        element.msRequestFullscreen();
      }
    },

是监听全屏后执行别的操作

在这里插入图片描述

然后换了一个思路去解决 因为页面有些div的高度是自适应的百分比写法
那么全屏和解除全屏的时候 div的高度肯定有变化 那么我们就直接监听div的高度变化来达到监听就行了

首先下载这个插件

   elementResizeDetectorMaker

import elementResizeDetectorMaker from "element-resize-detector";

mounted里面加这个代码就结束了
    const _this = this;
    const erd = elementResizeDetectorMaker();
    erd.listenTo(document.getElementById("moxing"), element => {
      _this.$nextTick(() => {
        var height = element.getBoundingClientRect().height
        console.log('elementResizeDetectorMaker', element,);
        if (height > 600) {
          this.fullscreen = true
        } else {
          this.fullscreen = false
        }
        //监听到事件后执行的业务逻辑
      });
    });

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值