前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >js页面全屏/退出全屏

js页面全屏/退出全屏

作者头像
流眸
发布2019-08-12 16:10:37
10.7K0
发布2019-08-12 16:10:37
举报

本文长度为 1378 字,建议阅读 4 分钟

需求

背景

  在做前端PC端项目中,我们经常会遇到让页面全屏的需求。大多情况下,这样可以使得用户在该页面更加专注,屏蔽掉该页面之外的干扰。

需求分析

  1. 状态判断
  2. 事件操作
1. 状态判断

首先,我们需要给出一个默认状态,即非全屏。然后,在此基础上我们进行DOM操作,每次用户进行操作时,我们先判断当前状态,进行相应的操作,操作过后改变当前状态即可。

2. 事件操作

注:下表中 de代表 document.documentElement

操作

浏览器

代码

全屏

W3C

de.requestFullscreen

全屏

CHROME

de.webkitRequestFullScreen

全屏

FIREFOX

de.mozRequestFullScreen

全屏

IE

de.msRequestFullscreen

还原

W3C

document.exitFullscreen

还原

CHROME

document.webkitCancelFullScreen

还原

FIREFOX

document.mozCancelFullScreen

还原

IE

document.msExitFullscreen

代码

注: 本demo在vue中使用。如果使用正常.html,自行将 @click转为正常点击事件(如 onclick)即可。

// html
<div @click="handleFullScreen">
    一个按钮
</div>

// js
data() {
    return {
        fullscreen: false  // 是否全屏
    }
},
methods: {
    // 全屏事件
    handleFullScreen(){
        let element = document.documentElement;
        // 判断是否已经是全屏
        // 如果是全屏,退出
        if (this.fullscreen) {
            if (document.exitFullscreen) {
                document.exitFullscreen();
            } else if (document.webkitCancelFullScreen) {
                document.webkitCancelFullScreen();
            } else if (document.mozCancelFullScreen) {
                document.mozCancelFullScreen();
            } else if (document.msExitFullscreen) {
                document.msExitFullscreen();
            }
            console.log('已还原!');
        } else {    // 否则,进入全屏
            if (element.requestFullscreen) {
                element.requestFullscreen();
            } else if (element.webkitRequestFullScreen) {
                element.webkitRequestFullScreen();
            } else if (element.mozRequestFullScreen) {
                element.mozRequestFullScreen();
            } else if (element.msRequestFullscreen) {
                // IE11
                element.msRequestFullscreen();
            }
            console.log('已全屏!');
        }
        // 改变当前全屏状态
        this.fullscreen = !this.fullscreen;
    }
}
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-05-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 流眸 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 状态判断
  • 2. 事件操作
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档