html 全屏不允许 退出,js实现进入全屏与退出

理想:

类型

名称

作用

属性

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 { }

HTML和jQuery可以配合来实现局部元素的全屏退出全屏功能。这里提供一个基本的思路和代码示例。 要实现局部元素的全屏,通常的做法是通过JavaScript将该元素的尺寸调整到视口(viewport)的大小。退出全屏时,则将元素恢复到原来的尺寸。在HTML中定义一个触发全屏的按钮和一个局部元素。使用jQuery来监听按钮的点击事件,然后使用浏览器的全屏API来切换全屏状态。 以下是一个简单的代码示例: HTML部分: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>局部全屏示例</title> <link rel="stylesheet" href="styles.css"> </head> <body> <!-- 触发全屏的按钮 --> <button id="toggleFullScreen">切换全屏</button> <!-- 局部元素 --> <div id="localFullScreenElement" style="width: 300px; height: 200px; background-color: #f0f0f0;"> 这里是局部全屏元素 </div> <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script> <script src="script.js"></script> </body> </html> ``` jQuery部分(script.js): ```javascript $(document).ready(function() { $('#toggleFullScreen').click(function() { var element = $('#localFullScreenElement'); if (!document.fullscreenElement) { // 如果当前不在全屏状态,进入全屏 element[0].requestFullscreen().then().catch(err => { alert(`Error attempting to enable full-screen mode: ${err.message} (${err.name})`); }); } else { // 如果当前在全屏状态,退出全屏 if (document.exitFullscreen) { document.exitFullscreen(); } } }); }); ``` 请注意,全屏API在不同的浏览器中可能有所不同,`requestFullscreen()` 和 `exitFullscreen()` 方法在某些浏览器中可能需要前缀,例如 `webkitRequestFullscreen` 或 `msExitFullscreen`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值