美文网首页
js实现进入全屏与退出

js实现进入全屏与退出

作者: 虎虎虎呼呼 | 来源:发表于2018-07-31 19:05 被阅读0次

理想:

类型 名称 作用
属性 fullscreenElement 当前处于全屏模式的DOM元素
属性 fullscreenEnabled 当前 document 是否进入了可以请求全屏模式的状态
方法 requestFullscreen() 请求进入全屏模式
方法 exitFullscreen() 退出全屏模式
事件 fullscreenchange 进入/退出全屏模式切换时会触发
事件 fullscreenerror 进入/退出全屏模式失败时会触发

现实:html5的全屏api处于一个杂乱状态,各个浏览器还是有着不同的实现方法

1.获取当前处于全屏模式的元素(注意screen的大小写),非全屏时为undefined
var ele=
document.fullscreenElement ||
document.mozFullScreenElement ||
document.webkitFullscreenElement ||
document.msFullscreenElement;
2.当前 document 是否进入了可以请求全屏模式的状态,我们常见的写法如下,

注意下面写法是错误的!

var isFull =
document.fullscreenEnabled ||
window.fullScreen ||
document.webkitIsFullScreen ||
document.msFullscreenEnabled;

原因,msFullscreenEnabled指的并不是浏览器是否处于全屏状态,引用微软官方一句话

Returns true if a document lets elements be displayed in full-screen mode. Otherwise it returns false.
返回当前元素是否可以已全屏展示

可以看出,它的作用并不是当前元素“是否”处于全屏状态,而是是否有能力变成全屏,所以判断当前是否全屏可以通过获取当前全屏元素来判断

3.跨浏览器进入全屏
function requestFullScreen(element) {
            if (!element) {
                element = document.body;                
            }
            if (element.requestFullscreen) {
                element.requestFullscreen();
            } else if (element.msRequestFullscreen) {
                element.msRequestFullscreen();
            } else if (element.mozRequestFullScreen) {
                element.mozRequestFullScreen();
            } else if (element.webkitRequestFullScreen) {
                element.webkitRequestFullScreen();
            }
        }
4.跨浏览器退出全屏
function exitFullScreen() {
            if (document.cancelFullScreen) {
                document.cancelFullScreen();
            } else if (document.mozCancelFullScreen) {
                document.mozCancelFullScreen();
            } else if (document.webkitCancelFullScreen) {
                document.webkitCancelFullScreen();
            } else if (document.msExitFullscreen) {
                document.msExitFullscreen()
            }
        }
4.全屏状态变化事件监听
  • fullscreenchange
  • webkitfullscreenchange
  • mozfullscreenchange
  • MSFullscreenChange
5.全屏error事件监听
  • fullscreenerror
  • webkitfullscreenerror
  • mozfullscreenerror
  • MSFullscreenError
6.关于样式

chrome:元素居中
其他:

position: fixed !important;
top: 0 !important;
right: 0 !important;
left: 0 !important;
bottom: 0 !important;

可通过以下方式覆盖样式

:-webkit-full-screen { }

:-moz-full-screen { }

:-ms-fullscreen { }

:fullscreen { }

最后上一个demo链接
https://laincarl.github.io/demos/fullscreen/

相关文章

网友评论

      本文标题:js实现进入全屏与退出

      本文链接:https://www.haomeiwen.com/subject/fwyzlftx.html